Linux/UNIX网络编程甘刚电子教案 第03章 基本TCP套接口编程.pptVIP

Linux/UNIX网络编程甘刚电子教案 第03章 基本TCP套接口编程.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Tcp套接字编程 TCP套接字编程(cont.) 基本套接字函数-socket #include sys/socket.h int socket(int family, int type, int protocol) 返回:非负套接字(sockfd)-成功;-1-出错。 family:协议族;type:套接字类型; protocol:一般为0,除原始套接字外。 family type AF_INET IPv4协议 SOCK_STREAM 字节流套接口 AF_INET6 IPv6协议 SOCK_DGRAM 数据报套接口 AF_LOCAL unix域协议 SOCK_RAW 原始套接口 AF_ROUTE 路由套接口 AF_KEY 密钥套接口 Protocol:指明此socket请求所使用的协议,可以使用如下相关符号常数来表示。 IPPROTO_TCP:表示TCP协议 IPPROTO_UDP:表示UDP协议 基本套接字函数-bind #include sys/socket.h int bind(int sockfd, const struct sockaddr *addr, socklen_len len) 返回:0-成功;-1-出错并置errno 该函数指明套接字将使用本地的哪一个协议端口进行数据传送(IP地址和端口号),注意:协议地址addr是通用地址。 Len是该地址结构(第二个参数)的长度。 一般而言,服务器调用此函数,而客户则很少调用它。 绑定地址时,可以指定地址和端口号,也可以指定其中之一,甚至一个也不指定。通配地址:INADDR_ANY,其值一般为0,它通知内核选择IP地址。 IP地址 端口 结果 通配地址 0 内核选择IP地址和端口号 通配地址 非0 内核选择IP地址,进程指定端口 本地IP 0 进程指定IP地址,内核选择端口 本地IP 非0 进程指定IP地址和端口号 若指定端口号为0,调用函数bind时,内核选择一个临时端口(在实际中,端口号都要指定);但若指定一个通配IP地址,则直到套接字已连接(TCP)或数据报已在套接字上发出(UDP),内核才选择一个本地IP地址。 bind函数的用法 … struct sockaddr_in addr; int port = 1234; int opt = SO_REUSEADDR; setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, opt, sizeof(opt)); bzero(server,sizeof(server)); addr.sin_family = AF_INET; addr.sin_addr.s_addr = htonl(INADDR_ANY); addr.sin_port = htons(port); if (bind(fd, (struct sockaddr *)addr, sizeof(addr)) == -1) { /* 错误处理 */ } 基本套接字函数-listen #include sys/socket.h int listen(int sockfd, int backlog) 返回:0-成功;-1-出错并置errno值; 函数listen仅被服务器调用,它完成两件事情: 函数listen将未连接的套接字转化成被动套接字,指示内核应接受指向此套接字的连接请求; 函数的第二个参数规定了内核为此套接字排队的最大连接个数; 对于给定的监听套接字,内核要维护两个队列 未完成连接队列 已完成连接队列 两个队列之和不超过backlog; listen函数(续) listen函数(续) 另外几点说明: 不同的实现对backlog有不同的解释,如源自Berkeley的实现将backlog增加一个模糊因子,把它乘以1.5,再作为两个队列之和; 不要把backlog定义为0,因为有些实现允许1个连接排队,而有些实现不允许有连接排队; 当一个客户SYN到达时,若两个队列都是满的,tcp就忽略此分节,且不发送RST。这是因为,这种情况是暂时的,客户tcp将重发SYN,期望不久的将来就能在队列中找到空闲条目。 如果发送RST,将会出现? 基本套接字函数-connect #incl

您可能关注的文档

文档评论(0)

118压缩包课件库 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档