我正在使用fork实现一个简单的父/子进程程序。我的目标是从单个父级创建用户输入数量的子进程,并将其PID存储在动态数组中。我设法使用fork创建子进程(我认为)并存储他们的PIDS。但是,当我存储PID时,我还存储了0 PID以及我认为与进程相关的另一个PID,但这个数字比子进程和父进程大得多。
如果只在父进程内部完成,这怎么会发生?
void createProcesses(int nProcess) {
int i;
int PID;
processIDS = calloc(nProcess, sizeof(long));
printf("*****Creating Processes*****\n");
printf("Parent Process: PID %d\n", getpid());
for (i = 0; i < nProcess; i++) {
PID = fork();
if (PID == 0) {
printf("Child Process: PID %d\n", getpid());
while(1){}
}
else if(PID != 0) {
// sleep(3);
// printf("Number of child processes created: %d\n", nProcess);
// updateProcessList();
*(processIDS + i) = PID;
printf("%d\n", PID);
}
}
for(i = 0; i < sizeof(processIDS); i++) {
printf("%ld\n", *(processIDS + i));
}
while(1) {
sleep(5);
updateProcessList();
}
}
processIDS is a long * global variable.
答案 0 :(得分:5)
问题在于:
for(i = 0; i < sizeof(processIDS); i++) {
printf("%ld\n", *(processIDS + i));
}
因为processIDS
是一个指针,它的大小是long *
的大小,大概是4或8,这不是你想要的。如果nProcess
的值小于此值,您将读取动态分配的数组的末尾,从而调用未定义的行为。
您知道已创建nProcess
个进程,因此请将其用于循环测试:
for(i = 0; i < nProcess; i++) {
printf("%ld\n", *(processIDS + i));
}