由于CreateNamePipe返回的是句柄, 并非可以select的描述符。所以这里不讨论CreateNamePipe
用socket来模拟的pipe方法如下:
int pipe(int fildes[2])
{
int tcp1, tcp2;
sockaddr_in name;
memset(&name, 0, sizeof(name)); name.sin_family = AF_INET; name.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
int namelen = sizeof(name); tcp1 = tcp2 = -1;
int tcp = socket(AF_INET, SOCK_STREAM, 0);
if (tcp == -1){
goto clean;
}
if (bind(tcp, (sockaddr*)&name, namelen) == -1){
goto clean;
}
if (listen(tcp, 5) == -1){
goto clean;
}
if (getsockname(tcp, (sockaddr*)&name, &namelen) == -1){
goto clean;
} tcp1 = socket(AF_INET, SOCK_STREAM, 0);
if (tcp1 == -1){
goto clean;
}
if (-1 == connect(tcp1, (sockaddr*)&name, namelen)){
goto clean;
}
tcp2 = accept(tcp, (sockaddr*)&name, &namelen);
if (tcp2 == -1){
goto clean;
}
if (closesocket(tcp) == -1){
goto clean;
} fildes[0] = tcp1; fildes[1] = tcp2;
return 0;
clean:
if (tcp != -1){ closesocket(tcp);
}
if (tcp2 != -1){ closesocket(tcp2);
}
if (tcp1 != -1){ closesocket(tcp1);
}
return -1;
}
|
缺点很明显
1、效率低下。
2、占用了两个TCP端口。
3、accept的返回值未必就是tcp1连接过来的(多线程或者别的进程在干预), 所以最好通过发送数据进行确认。
4、由于不是匿名的, 所以可以在netstat里面看到。
优点只有一个, 可以使用select调用。
阅读(3757) | 评论(0) | 转发(0) |