我必须为我的班级作业编写一个线程示例。不知何故,我在创建了我的孩子之后得到了一个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故障 - 其余的应该没问题(我认为;))
问候!!
答案 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)。
应该修复它。