其他分享
首页 > 其他分享> > 高级I/O函数

高级I/O函数

作者:互联网

pipe、socketpair

#include<unistd.h>
int pipe(int fd[2]);

要想实现双向的数据传输,应该使用两个管道。
管道内部传输的数据时字节流,这和TCP字节流的概念相同。但TCP写入多少字节的数据决定对方的接受窗口和拥塞窗口,而管道本身有一个容量限制,默认是65536字节。我们可以使用fcntl函数来修改管道容量。

#include<sys/types.h>
#include<sys/socket.h>
int socketpair(int domain,int type,int protocol,int fd[2]);

domain只能用AF_UNIX,我们只能在本地使用这个双向管道。


dup、dup2

#include<unistd.h>
int dup(int file_descriptor);
int dup(int file_descriptor_one,int file_descriptor_two);

dup函数创建一个新的文件描述符,并且与原来file_descriptor文件描述符指向想通过的文件或管道或网络连接。并且dup返回的文件描述符总是取系统当前可用的最小整数值。 dup2和dup类似,不会它返回一个不小于file_descriptor_two的整数值。

dup和dup2并不继承源有文件描述符的属性,如cloexec或noblock等。


利用dup函数实现了一个基本的CGI服务器。

  1. 先关闭标准输出文件描述符STDOUT_FILENO(其值为1).
  2. 因为dup总是返回系统最小可用的整数值,则返回1.
  3. 这样以来,服务器标准输出的内容会直接发送到对应的socket上。
int connfd=accept(sockfd,(struct sockaddr*)&client,&client_addrlen);
if(connfd<0){
    printf("errno is: %d\n",errno);
}else{
    close(STDOUT_FILENO);//关闭标准输出文件符
    dup(connfd);
    printf("abcd\n");
    close(connfd);//我猜这个关了之后,上一行dup(connfd)返回的描述符就无效了。
}

标签:函数,int,高级,descriptor,描述符,file,dup,connfd
来源: https://blog.csdn.net/m0_43602209/article/details/113920814