linux下tcp/ip编程

1.DOS攻击就是与服务器建立大量链接;


2.请求连接的tcp报文syn=1;


3.sock_RAM直接操作网络层报文;


4.ip1^mask1==ip2^mask2,网络地址相同,在同一子网内;


5.sock_STREAM,套接字流,UDP协议;


6.在linux下中文与英文的切换用ctrl+空格;


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访问自己;

猜你喜欢

转载自blog.csdn.net/u010014980/article/details/20614069