- 1、本文档共98页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
每一种知识都需要努力,
都需要付出,感谢支持!知识就是力量,感谢支持!一一一一谢谢大家!!9.2.3套接字
套接字(Socket)是目前进行网络编程使用最为广泛的技术。简单地说,套接字就是使用UNIX系统中的文件描述符实现系统进程间通讯的一种方法。
从历史发展来看,套接字起源于UNIX系统,主要有两种类型:UNIX域套接字(DomainSocket)和伯克利套接字(BerkelySocket)。现在伯克利套接字(以下简称套接字)已经
成为事实上的标准,广泛用于各种平台之间的网络通讯,例如ftp、telnet、http等通讯在底层都是使用Socket编程技术实现的。在ISO的OSI七层模型中,传输层采用的协议有两种,分别是TCP和UDP。其中TCP是面向连接的,提供可靠传输;UDP是无连接的,传输的信息可能发生丢失或者次序混乱。套接字有两种类型分别对应这两种协议:流式套接字(SOCK_STREAM)和数据报套接字(SOCK_DGRAM)。流式套接字的处理流程如图9.2所示,读者可以自行分析数据报套接字的处理流程。图9.2流式套接字的处理流程记住一点,在Linux中所有的内容归根结底都是文件,Socket也不例外。一个Socket对应一个描述符,它是一个整型数,还有几个结构和Socket有关:
structsockaddr{
sa_family_tsa_family;
/*address族,对于IP协议是AF_INET*/
charsa_data[14];
/*14字节的协议地址*/
}为了处理简单,程序员可以定义一个类似于sockaddr的结构在程序中使用:
structsockaddr_in{
sa_family_tsin_family;
/*address族,对于IP协议是AF_INET*/
unsignedshortsin_port; /*端口号*/
structin_addrsin_addr; /*Internet地址*/
unsignedcharsin_zero[8];
/*添0,保证该结构和sockaddr结构大小相同*/
}sin_addr和sin_port惟一定义了一个套接字,因此可以进行惟一的访问。sockaddr_in结构中的sin_addr成员是in_addr的结构,定义如下:
structin_addr{
unsingnedlongs_addr;
}在Linux中,sockaddr结构的定义位于linux/socket.h,sockaddr_in和in_结构的定义位于linux/in.h,和我们上面的定义稍微有些差别。同时,Linux还提供了相当丰富的进行类型转换的函数,例如有一个structsockaddr_inina的变量,希望将其IP地址赋值为,可以这样使用:
ina.sin_addr.s_addr=inet_addr(“”)
对Socket进行操作的系统调用有很多,下面我们简单介绍图8.2中涉及到的一些系统调用。(1)socket()。socket()用来创建一个套接字描述符,函数原型如下:
intsocket(intdomain,inttype,intprotocol)
参数domain指明协议类型,对于IP协议该参数应该设置为PF_INET;type指明套接字类型,流式套接字是SOCK_STREAM,数据报套接字是SOCK_DGRAM。
(2)bind()。bind()用于服务器端。其函数原型为
intbind(intsockfd,structsockaddr*my_addr,intaddrlen)
该函数将一个套接字描述符和一个sockaddr结构的参数my_addr绑定在一起。addrlen是structsockaddr的大小。(3)listen()。listen()用于服务器端。其函数原型为
intlisten(ints,intbacklog)
服务器端完成bind()操作之后,就要调用listen(),开始侦听来自客户端的connect()发出的连接请求。如果有请求到达,就将其加入请求队列(队列长度由backlog参数指定),然后调用accept()处理。(4)ac
文档评论(0)