<TCP/IP网络编程> Chap13. 多种I/O函数

send & recv 函数

#include <sys/socket.h>
/* 
 * @params
 *   sockfd: 表示与数据传输对象的连接的套接字文件描述符
 *   buf: 保存待传输数据的缓冲地址值
 *   nbytes: 待传输的字节数
 *   flags: 传输数据时指定的可选项信息
 */
ssize_t send(int sockfd, const void *buf, size_t nbytes, int flags);    // 成功时返回发送的字节数,失败时返回-1

/* 
 * @params
 *   sockfd: 表示与数据接收对象的连接的套接字文件描述符
 *   buf: 保存接收数据的缓冲地址值
 *   nbytes: 可接收的最大字节数
 *   flags: 接收数据时指定的可选项信息
 */
ssize_t recv(int sockfd, void *buf, size_t nbytes, int flags);    // 成功时返回发送的字节数(收到EOF时返回0),失败时返回-1
可选项 含义 send recv 示例
MSG_OOB 传输一个字符的带外数据 * * oob_recv.c和oob_send.c
MSG_PEEK 验证输入缓冲中是否存在数据 * peek_recv.c和peek_send.c
MSG_DONTROUTE 数据传输过程中不参照路由表,在本地网络中寻找目的地 *
MSG_DONTWAIT 调用I/O函数时不阻塞 * *
MSG_WAITALL 直到接收全部请求的字节数再返回 *
# gcc oob_recv.c -o oobrecv
# ./oobrecv 9190
123
Urgent message: 4 
567
Urgent message: 0 
89
# gcc oob_send.c -o oobsend
# ./oobsend 127.0.0.1 9190
Connected
# gcc peek_recv.c -o peekrecv
# ./peekrecv 9190
Buffering 3 bytes: 123 
Reading 3 bytes: 123 
# gcc peek_send.c -o peeksend
# ./peeksend 127.0.0.1 9190
Connected


readv & writev 函数

#include <sys/uio.h>

struct iovec {
    void *iov_base;    // 缓冲地址
    size_t iov_len;    // 缓冲大小
}

/* 
 * @params
 *   filedes: 表示数据传输对象的套接字文件描述符/文件或标准输出描述符
 *   iov: iovec结构体数组的地址值,结构体iovec中包含待发送数据的位置和大小信息
 *   iovcnt: 第二个参数的数组长度
 */
ssize_t writev(int filedes, const struct iovec * iov, int iovcnt);    // 成功时返回发送的字节数,失败时返回-1

/* 
 * @params
 *   filedes: 接收数据的套接字文件描述符/文件或标准输出描述符
 *   iov: iovec结构体数组的地址值,结构体iovec中包含保存数据的位置和大小信息
 *   iovcnt: 第二个参数的数组长度
 */
ssize_t readv(int filedes, const struct iovec * iov, int iovcnt);    // 成功时返回发送的字节数,失败时返回-1
# gcc writev.c -o wv
# ./wv
ABC1234
Write bytes: 7
# gcc readv.c -o rv
# ./rv
I like reading.  
First message: I lik 
Second message: e reading.


习题

  1. 下列关于MSG_OOB可选项的说法错误的是?
    a. MSG_OOB指传输Out-of-band数据,是通过其他路径高速传输数据。
    b. MSG_OOB指通过其他路径高速传输数据,因此,TCP中设置该选项的数据先到达对方主机。
    c. 设置MSG_OOB使数据先到达对方主机后,以普通数据的形式和顺序读取。也就是说,只是提高了传输速度,接收方无法识别这一点。
    d. MSG_OOB无法脱离TCP的默认数据传输方式。即使设置了MSG_OOB,也会保持原有传输顺序。该选项只用于要求接收方紧急处理。
    abc。
  2. 利用readv&writev函数首发数据有何优点?分别从函数调用次数和I/O缓冲的角度看给出说明。
    相比于分次读进来拷贝到不同数组,这个函数只需要调用一次。如果关闭了NAGLE算法,用这个函数可以将数据打包发送节省带宽。
  3. 通过recv函数验证输入缓冲是否存在数据时(确认后立即返回),如何设置recv函数最后一个参数中的可选项?分别说明各可选项的含义。
    MSG_PEEK|MSG_DONTWAIT。验证输入缓冲区是否存在数据|非阻塞。


附录

[1] Github

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。