int pipe_init(char *myfifo){ int fd; int res; //判断是否存在命名管道文件 if(access(myfifo,F_OK) != -1){ printf("%s管道存在.\n",myfifo); remove(myfifo); } res = mkfifo(myfifo,0777); if (res < 0) { printf("create fifo failure\n"); exit(1); }else{ printf(">>>Opening pipe...\n"); } /* 打开命名管道 */ fd = open(myfifo, O_WRONLY|O_NONBLOCK);//写,非阻塞状态 if(fd != NULL){ printf(">>>Writing data to Pipe...\n"); }else{ printf(">>> open XXX"); } return fd; }
时间: 2024-03-09 21:47:54 浏览: 85
在这段代码中,存在以下几个问题:
1. open函数返回的是文件描述符,而不是NULL。因此,判断文件是否成功打开,应该使用文件描述符是否小于0来判断,而不是是否等于NULL。
2. 在使用open函数打开管道时,应该使用O_WRONLY|O_NONBLOCK模式。然而,在本代码中却使用了O_WRONLY|O_NONBLOCK这种形式,这是错误的。正确的模式应该是O_WRONLY|O_NONBLOCK。
3. 如果open函数返回的文件描述符小于0,则应该在出错处理中进行处理,例如输出错误信息并退出程序。
下面是修改后的代码:
```c
int pipe_init(char *myfifo) {
int fd;
int res;
// 判断是否存在命名管道文件
if (access(myfifo, F_OK) != -1) {
printf("%s管道存在.\n", myfifo);
remove(myfifo);
}
res = mkfifo(myfifo, 0777);
if (res < 0) {
printf("create fifo failure\n");
exit(1);
} else {
printf(">>>Opening pipe...\n");
}
// 打开命名管道
fd = open(myfifo, O_WRONLY | O_NONBLOCK);
if (fd < 0) {
printf(">>>Failed to open pipe\n");
exit(1);
} else {
printf(">>>Writing data to Pipe...\n");
}
return fd;
}
```
希望能帮到您。
阅读全文