在Linux上的线程C程序中的Segfault

时间:2012-05-07 22:00:06

标签: c linux multithreading segmentation-fault

我必须为我的班级作业编写一个线程示例。不知何故,我在创建了我的孩子之后得到了一个Segfault - 通过copy()进行处理(不得不遗憾地使用它)。

void thread(void);
#define CLONE_VM        0x00000100
#define ANSWER_TRUE     "t"
#define ANSWER_FALSE    "f"

static char stack[2];

int main(void) {
void** childThreadBP = NULL;
void** childThread = NULL;

int pid = 0;

puts("create stack for child process...");
void ** new_stack = (void **) malloc(128);    
//new_stack = (void **) ((char *)new_stack + 128); 

puts("create child process...");    
pid = clone(thread, new_stack, CLONE_VM, NULL);

puts("write PID to shared stack...");
stack[0] = (char) pid;

puts("child answered:");
while(1){}
if (stack[1] == ANSWER_TRUE) {
    puts("PIDs are equal.");
}
else {
    puts("PIDs are NOT equal.");
}
return EXIT_SUCCESS;
}

void thread(void) {
puts("[child]: I'm alive!");
int pidSelf;

pidSelf = getpid();
if (pidSelf == (int)stack[0]) {
    puts("[child]: dad the PID you gave me is correct!");
    stack[1] = ANSWER_TRUE;
}
else {
    puts("[child]: dad the PID you gave me is NOT correct!");
    stack[1] = ANSWER_FALSE;
}
}

也许你看到我的错误是什么...... - 代码格式出了什么问题?!

我只需要帮助修复seg故障 - 其余的应该没问题(我认为;))

问候!!

1 个答案:

答案 0 :(得分:2)

你有一些问题。第一个是Martin James所说的,你需要更大的堆栈大小。我使用16384,工作正常。其次,你需要传入内存空间的顶部,你的行:

new_stack = (void **) ((char *)new_stack + 128); 

很好,取消注释并将其更改为更大的堆栈大小:

void ** new_stack = (void **) malloc(16384);    
new_stack = (void **) ((char *)new_stack + 16384); 

第三,您的PID存储存在问题。堆栈数组必须是整数,因为pid可以大于char变量可以容纳的值(我的PID为25689)。

应该修复它。