write/read
ssize_t write (int fd, const void * buf, size_t count);
ssize_t read(int fd, void * buf, size_t count);
write()会把参数buf所指的内存写入count个字节到参数放到所指的文件/缓冲区内,即将用户缓冲区当中的内容放入到内核缓冲区(socket缓冲区)当中。当内核缓冲区已满时,write函数会阻塞。
read()会把参数fd所指的文件传送count 个字节到buf 指针所指的内存中。数据在不超过指定的长度的时候有多少读多少,没有数据就会一直等待。所以一般情况下::我们读取数据都需要采用循环读的方式读取数据,因为一次read 完毕不能保证读到我们需要长度的数据,read 完一次需要判断读到的数据长度再决定是否还需要再次读取。
阻塞情况下
在阻塞条件下,read/recv/msgrcv的行为:
- 如果没有发现数据在网络缓冲中会一直等待,
- 当发现有数据的时候会把数据读到用户指定的缓冲区,但是如果这个时候读到的数据量比较少,比参数中指定的长度要小,read 并不会一直等待下去,而是立刻返回
非阻塞情况下
在非阻塞的情况下,read 的行为
- 如果发现没有数据就直接返回,
- 如果发现有数据那么也是采用有多少读多少的进行处理.
recv/send
s

本文介绍了Linux系统调用write、read、recv、send、recvfrom、sendto以及readmsg和sendmsg的区别。write和read用于文件或socket的读写,可能阻塞或非阻塞。recv/send常用于TCP,可能无法一次性读取完整数据。recvfrom/sendto适用于UDP,每次接收或发送可能包含不同数量的数据。readmsg和sendmsg则提供了更复杂的读写功能,能处理多个缓冲区。
最低0.47元/天 解锁文章
2603

被折叠的 条评论
为什么被折叠?



