1.DOS攻击就是与服务器建立大量链接;
(2)然后用VA_START宏初始化刚定义的VA_LIST变量;
(3)然后用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型(如果函数有多个可变参数的,依次调用VA_ARG获取各个参数);
(4)最后用VA_END宏结束可变参数的获取。
注意:
(1)可变参数的类型和个数完全由程序代码控制,它并不能智能地识别不同参数的个数和类型;
(2)如果我们不需要一一详解每个参数,只需要将可变列表拷贝至某个缓冲,可用vsprintf函数;
(3)因为编译器对可变参数的函数的原型检查不够严格,对编程查错不利.不利于我们写出高质量的代码;
将这个socket绑定在某个文件上(AF_UNIX)或某个端口上(AF_INET),我们会分别介绍这两种。
将保存 struct sockaddr_un 结构的长度的变量类型,由 int 类型改为 socklen_t 类型。
将 int 类型改为 socklen_t 类型之后,编译含有 accept( ; ; ;) 的代码,顺利通过编译。
2.请求连接的tcp报文syn=1;
3.sock_RAM直接操作网络层报文;
4.ip1^mask1==ip2^mask2,网络地址相同,在同一子网内;
5.sock_STREAM,套接字流,UDP协议;
6.在linux下中文与英文的切换用ctrl+空格;
扫描二维码关注公众号,回复:
12432574 查看本文章

7.va_list用法:
(1)首先在函数里定义一具VA_LIST型的变量,这个变量是指向参数的指针;(2)然后用VA_START宏初始化刚定义的VA_LIST变量;
(3)然后用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型(如果函数有多个可变参数的,依次调用VA_ARG获取各个参数);
(4)最后用VA_END宏结束可变参数的获取。
注意:
(1)可变参数的类型和个数完全由程序代码控制,它并不能智能地识别不同参数的个数和类型;
(2)如果我们不需要一一详解每个参数,只需要将可变列表拷贝至某个缓冲,可用vsprintf函数;
(3)因为编译器对可变参数的函数的原型检查不够严格,对编程查错不利.不利于我们写出高质量的代码;
将这个socket绑定在某个文件上(AF_UNIX)或某个端口上(AF_INET),我们会分别介绍这两种。
8.在Linux下编译程序,accept( ; ; ;) 函数的第三个参数提示“从类型‘int*’到类型‘socklen_t*’的转换无效”,于是乎,我发现还有个 socklen_t 类型。
解决办法:将保存 struct sockaddr_un 结构的长度的变量类型,由 int 类型改为 socklen_t 类型。
将 int 类型改为 socklen_t 类型之后,编译含有 accept( ; ; ;) 的代码,顺利通过编译。
9.任何计算机都可以通过127.0.0.1或自己主机ip访问自己;