深入理解connect()、listen()、accept()、backlog参数的含义

这个图将三个函数的关系描述的很清楚
在这里插入图片描述
各种资料都说listen()是监听客户端连接,等待连接请求,,我一直蒙在鼓里,一直想不透,我感觉这样说就有误导性!下面是我的理解:

backlog的理解:
他根本就不是监听,说监听会让我以为它会阻塞在那监听,但是它阻塞个屁呀,一点都没阻塞直接就执行过去了,它的第二个参数backlog就是告诉内核完成队列的长度(完成三次握手的队列的长度)
然后内核和connect()完成三次握手,在第一次握手的时候放入半连接的队列里,完成三次握手后从半连接队列里放到完成队列里, 之后accept()从完成队列里挨个取出再返回一个fd专门用来和这个客户端沟通,当这个队列什么也没有时accept()就会阻塞在那里,当队列一下子满了,再进来的就会被舍弃掉

listen的里一个作用
被listen函数作用的套接字,就是那个socket()函数返回的套接字,它开始是一个主动连接的套接字,
也就是此时系统以为用户会对这个套接字调用connect函数,期待它主动与其它进程连接,然而在服务器编程中,用户希望这个套接字可以接受外来的连接请求,也就是被动等待用户来连接。由于系统默认时认为一个套接字是主动连接的,所以需要通过某种方式来告诉系统,用户进程通过系统调用listen来完成这件事。在listen函数中有将这个套接字设置为监听状态的代码。所以一开始创建的这个套接字他就一直用来监听请求嘛!处理请求还得需要accept()返回的新的套接字去完成!(这个新的套接字就和客户端创建的那个套接字进行recvsend…,就像管道一样)

哪里理解有问题还请大佬指出,谢谢

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值