gpt4 book ai didi

c - 使用 select() 监视管道时出现段错误

转载 作者:太空宇宙 更新时间:2023-11-04 03:52:56 25 4
gpt4 key购买 nike

我正在做一个项目,其前提是创建一个进程树,其中父进程通过管道向其两个子进程中的每一个发送一半的字符串(数字),然后,当数字 <= 2 统计数字出现的次数并传递统计(希望以整数数组的形式,返回给父级。

我还处于构建这个东西的初始阶段,我一直在使用 select();现在我在尝试执行程序时遇到 SEG_FAULT,当我将它放入 Eclipse 时,错误(列为 EXC_BAD_ACCESS:无法访问内存)似乎是在我第二次尝试将文件描述符设置为读取时发生的fd 集合。

我不知道问题出在哪里。这段代码的大部分与问题无关,但我将其包括在内以防万一我在某处犯了草率的错误。问题似乎出现在 bit_count 函数中。我给它贴上了标签。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/select.h>
#include <sys/wait.h>

int bit_count(char *passed, int len);

main(int argc, char *argv[]){
FILE *fp;
fp = fopen(argv[1], "r"); //open the file for reading
if( fp == NULL ) { //file open error
perror ("Error opening file");
exit(EXIT_FAILURE);
}

fseek(fp, 0, SEEK_END); //seek to find file size
long int length = ftell(fp); //ftell file length
rewind(fp); //rewind pointer to begin read
char *string = malloc(length+1); //malloc space for the string from the file.
fread(string, 1, length, fp); //begin read
fclose(fp);

if( length < 2){ //make sure string length is greater than 2. Just in case.
printf("File too small. Must have greater than 2 binary digits\n");
return 0;
}

bit_count(string, length); //call bit_count
return 0;
}

int bit_count(char *passed, int len){

int fd1[2], fd2[2]; //file descriptors used for left and right children
fd_set read_set;
fd_set write_set;
struct timeval tv;
tv.tv_sec = 60;
tv.tv_usec = 0;
FD_ZERO(&read_set);
FD_SET(fd1[0], &read_set);
FD_SET(fd2[0], &read_set); //WHERE EXC_BAD_ACCESS OCCURS
pipe(fd1);
pipe(fd2);

pid_t kid = fork();
if(kid == -1) printf("forking failed.");
if (kid == 0){ //first child process
int retval = select(2, &read_set, NULL, NULL, &tv);
if (retval == -1){
printf("Select Error.\n");
}
char *lstring = malloc(len/2+1);
read(fd1[0], lstring, sizeof(lstring));
printf("left %s", lstring);
exit(1);
}
else{ //parent process
pid_t kid2 = fork();
if (kid2 == 0) { //second child process

int retval = select(2, &read_set, NULL, NULL, &tv);
if (retval == -1){
printf("Select Error.\n");
}
char *rstring = malloc(len/2);
read(fd2[0], rstring, sizeof(rstring));
printf("Right %s", rstring);
//execl("child.c", parent);
exit(1);
}

else{

int status;

//create character arrays for first and second half of string
//then copy
char *lstring = malloc(len/2+1);
char *rstring = malloc((len/2)+2);
strncpy(lstring, passed, len/2);
strcpy(rstring, &passed[(len/2)]);
printf("ppp %s", lstring);

write(fd1[1], lstring, sizeof(lstring));
write(fd2[1], rstring, sizeof(rstring));
waitpid(kid, &status, NULL);
waitpid(kid2, &status, NULL);



}

return 0;
}
return 0;

最佳答案

您似乎没有在 fd1[] 和 fd2[] 中初始化/添加文件描述符。您正在尝试将 empty/uninitialized int[] 存储在 fd_set 结构中。这就是为什么你得到 EXC_BAD_ACCESS


注意:

EXC_BAD_ACCESS 是什么意思?

EXC_BAD_ACCESS 意味着消息被发送到内存中没有类实例来执行它的点。因此“错误访问”

EXC_BAD_ACCESS 何时发生?

在 3 种情况下您将获得 EXC_BAD_ACCESS:

  1. 一个对象没有被初始化
  2. 一个对象已经被释放
  3. 其他不太可能发生的事情

关于c - 使用 select() 监视管道时出现段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19336913/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com