<强>开发环境强>
运行平台:Ubantu LTS
14.04<强>疑问引导强>
问题1:头文件的疑问:
<代码> # include & lt; sys/socket.h> 代码>与<代码> # include & lt; linux/socket.h> 代码>有何区别?
解答:
1。使用diff查看:adc分别表示添加,删除,修改
2。其实是路径的不同导致有不同的socke.h文件,,,
3只& lt; sys/socket.h>是互联网协议的家庭,也就是tcpip协议的应用层接口,,,
4只;& lt; linux/socket.h>目前暂时未弄的懂,但不是接口函数,估计是系统函数。它应该是被操作系统使用,猜测该文件在tcpip的传输层
问题2:大小端字节序问题:
1. c语言检测:利用指针取值和取址的交叉应用,为了增强网络移植性
2。而插座提供了字节序转换函数:h:主机;n:网络;l: long32位;销售:short16位,,,
3。htonl:将主机的32位主机字节序(ip地址),转换为网络字节序(一列数据)。
问题3:就一个服务器,一个客户端来说,有如下的对应角色说法:
对象第一次 对象第二 服务器 客户端 监听者 广播者 提供服务 请求服务解析套接字编程整体过程:
建立与删除
服务器和客户端通过同一的套接字信道通信,而创建一个套接字信道,提供插座连接。
<代码> int插座(int, int类型,int协议);
代码>
域(域):各个域以AF_XXX命令,意指地址族。决定使用何种的地址类型,确定通信特性:包括地址格式
类型:确定套字节的类型,(还)可以自由增加类型。
常用:SOCK_STREAM(即:TCP)和SOCK_DGRAM(即:UDP)
协议:指定套接字使用的传输协议编号,一般直接设置为0即可,以此表示为给定的域和套接字类型选择默认的传输协议。
返回值:正确返回套接字处理代码(我称之为套接字文件描述符),错误返回1。该数值将存储使用。
服务器和客户端通都可以,关闭插座通信IO
<代码> int关闭(int, int);代码>
s:代表socket_fd,需要关闭的套接字文件描述符
如何:为一种方式
关闭是使套接字信道处于不活动状态。可以让该信道关闭写端,而继续接收该套接字读端以此确定数据何时结束,然后再使用亲密来关闭这个信道。
<>强连接关系强>
创建和销毁或关闭IO之后,需要知道如何标识一个目标通信进程。
原因:网络有多个计算机,某台计算机上运行着多个程序(进程)。下面是两层关系:
1)目标计算机的网络地址
2)目标计算机上的目标进程的所代表的端口号
所以,目前你需要了解到的有下面几点:
1。字节序:直接看上面的问题2即可,简单的转换关系。
2。地址格式:根据不同的因特网地址,在& lt; netinet/in.h>定义不同的结构体,部分插座函数参数调用。如下,,,
3。定义地址结构体,根据实际装入数值作为套接字API实参,,,
4。地址进制转换:对地址进行二进制与文本字符串格式之间的转换.inet_ntop或inet_pton
绑定接着,对于服务端来说,需要绑定(关联)地址和套接字。为给定的sockfd关联一个sockaddr结构数据。只有服务端将套接字绑定在(域)地址上,客户端才能够连接(连接)成功。
<代码> int绑定(int sockfd, struct sockaddr * my_addr, int就奇怪);
代码>
sockfd:套接字文件描述符,是套接字返回的值
my_addr:(服务器)网络地址信息
返回值:判断是否正确绑定地址和套接字
连接在此之前,我们创建了套接字(socket),建立连接基础(绑定)。那么,就这就是为了在通信之前,将套接字信道连接起来。
<代码> int连接(int sockfd, struct sockaddr * serv_addr, int就奇怪);
代码>
sockfd:套接字文件描述符,是套接字返回的值
serv_addr:网络地址信息
返回值:判断是否正确连接,客户端程序必须要能够处理连接返回的错误。
到目前,你或许已经发现了,联系函数的参数类型与个数都跟绑定是一样的(他们的值并不一样,我所说的是形式),结合一起去理解,会更好。
毕竟,根据TCPIP协议,需要连接的信息:IP地址,端口号,就已经足够了。至于其余的MAC地址等等,在插座里的面,我们不需要理会。