今天看linux进程的时候发现wait函数的返回值似乎和书上说的不一样,书上是这么说的
wait函数的原型是:pid_t wait(int *status)
参数 status 用来保存被收集进程退出时的状态,它是一个指向 int 类型的指针。但如果不关心子进程是如何死植的,而只想把该僵死进程销毁(事实上绝大多数是这种情况),则可以设置参数为 NULL,其调用形式如下∶
pid = wait(NULL);
如果成功,wait( )会返回被收集的子进程的进程 ID;如果调用进程没有子进程,则会失败,此时 wait( )返回-1,同时 errno 被置为 ECHILD。
也就是说函数返回的是pid 而 参数传出的是statu,但是看下面一张图
可以看到原本应该是pid的sss输出的是statu,而参数传出的是pid,这似乎与书上的相悖,当我们稍作修改时,得到以下结果
我们传入一个空指针,然后惊奇的发现sss又恢复了它原本的功能,变成了pid。
我们再仔细想想,其实我们之前第一步是有问题的,因为书上写的是传入Int类型的指针而我们传入的是int型整数,于是我们再次修改,后得到以下结果
这下终于对了,看来确实是传入参数的问题,
修改后的代码如下
#include <stdio.h>
#include <unistd.h>
#include<stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
int main(void) {
int data = 0 ;
int sss;
int *pid ;
int choose = 0 ;
while((choose = getchar( ))!='q') {
switch(choose) {
case '1':
pid = fork( );
if(pid < 0 ) {
printf("Error !\n");
}
if(pid == 0 ) {
data++;
exit(0);
}
sss=wait(&pid);
printf("%d\n",sss);
printf("%d\n",pid);
if(pid > 0 ) {
printf("data is %d\n",data);
}
break;
case '2' :
pid = vfork( );
if(pid < 0 ){
perror("Error !\n");
}
if(pid == 0 ) {
data++;
exit(0);
}
sss=wait(&pid);
printf("%d\n",sss);
printf("%d\n",pid);
if(pid > 0 ) {
printf("data is %d\n",data);
}
break;
default :
break;
}
}
}