1.每一个TCP套接字都有一个发送缓冲区,可以使用SO_SNDBUF套接字选项来更改该缓冲区,当使用netstat查看时可以看到
2.当某个应用进程调用write,内核从该进程的缓冲区复制所有数据到所写套接字的发送缓冲区。
- 此时从用户态(用户进程调用write)切换到内核态(write执行过程,数据在缓冲区之间的复制)
- 若套接字的发送缓冲区容不下该应用进程的所有数据,在套接字具有阻塞属性(默认设置)的情况下,应用进程投入睡眠
- 直到应用进程缓冲区所有数据都复制到套接字缓冲区,write系统调用才返回。
- write调用成功返回并不能说明对端tcp或应用进程已经接收到数据。只能说明我们把数据成功复制到套接字的发送缓冲区,应用进程的缓冲区可以重新使用了
原文地址:https://www.jb51.cc/bash/392277.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。