![](/img/trans.png)
[英]Read/write exactly N bytes from/to file descriptor with C on Unix
[英]c fork pipe and read fucntion gives random bytes from file descriptor
嗨,我的C程序遇到了一些问题。 目标是fork
两次,然后使用pipe
将一些数据从子2传递到子1,然后将一些不同的数据从子1传递到父,最后在父中打印出来。 这是我的代码:
int main(void)
{
int f,f2,nread;
int pfd[2], pfd2[2];
char buffer[512], *str;
if(pipe(pfd)==-1) {
errorHandler("pipe");
}
if((f=fork())==-1) {
errorHandler("fork 1");
} else if(f == 0) {
/*child 1*/
if(pipe(pfd2)==-1) {
errorHandler("pipe 2");
}
if((f2=fork())==-1) {
errorHandler("fork 2");
} else if(f2 == 0) {
/*child 2*/
close(pfd[0]);
close(pfd[1]);
close(pfd2[0]);
str = "rollin";
printf("-child 2 writing: %s\n", str);
if(write(pfd2[1], &str, BUFFSIZE)==-1) {
errorHandler("write 2");
}
} else {
/*child 1*/
close(pfd[0]);
close(pfd2[1]);
if((nread=read(pfd2[0], &buffer, 512))==-1) {
errorHandler("read child 1");
}
buffer[nread] = 0;
printf("child 1 read data %d [%s]\n", nread, buffer);
str = "patrollin patrolling hehe";
printf("-child 1 writing %s\n", str);
if(write(pfd[1], &str, BUFFSIZE)==-1) {
errorHandler("write");
}
}
} else {
/*parent*/
close(pfd[1]);
if((nread=read(pfd[0], buffer, sizeof(buffer)))==-1) {
errorHandler("read");
} else {
buffer[nread] = 0;
printf("parent read data: %d [%s]\n", nread, buffer);
}
}
return 0;
}
输出是读取数据(如我指定的512字节),但不是我发送的数据。 我从内存中取了一些随机符号(文件描述符正确通过了,对吗?)。 我来这里的原因是我无法弄清楚这是怎么回事。 我有一个程序,它只有一个分叉并且动作类似,它基于相同的技术并且正在运行。 谁能给我一个提示我做错了什么?
要read
的第二个参数是指向缓冲区的指针。 要write
的第二个参数是指向要写入的数据的指针。 所以你应该使用
read(pfd2[0], buffer, 512)
和
write(pfd2[1], str, BUFFSIZE)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.