Linux 父进程如何获取子进程返回值?parent get child process return value,fork,wait,wait_pid

【by lanmanck】

创建子进程一般用fork,因为用execv后就不返回了,父进程无法跟子进程通信。

这里有个例子:

http://blog.csdn.net/wallwind/article/details/6998602

父进程fork后,可以使用wait和wait_pid来等待子进程结束,wait/wait_pid可以阻塞也可以不阻塞,权威解析在这里:

http://linux.die.net/man/3/wait

示例代码修改一下:

#include "stdio.h"  
#include"stdlib.h"
#include<unistd.h>
#include<sys/types.h>
#include <sys/wait.h>

int main(void)  
{
	int child_ret;
	pid_t pid1,pid2;
	printf("before fork\n");

	if((pid1=fork())<0){
		printf("fork error");

	}else if(pid1==0){
		printf("child process's pid=%d,sleep 3 sec\n",getpid());
		sleep(3);
		exit(-3); //line19

	}else{
		printf("parent process wait child terminate...\n");
		pid2=wait(&child_ret);
		printf("wait process's pid=%d,status=0x%X,exit value=%d(0x%X)\n",pid2,child_ret,
				WEXITSTATUS(child_ret),WEXITSTATUS(child_ret));
	}  

	exit(0);  

}  

我们主要关注line19,因为用
pid2=wait(&child_ret);

等待后,主要就是看child_ret的值,这样父进程好做进一步判断;

通过打印得知:

1、如果子进程调用exit(val);退出,则child_ret的高八位就是val,即child_ret = (val<<8) | 0;

使用WEXITSTATUS(child_ret)可以直接得到低八位,即val的值。

2、如果子进程意外中止,例如用了非法指针,改一下,在exit(-3)前加上:

*(int*)0 = 1234;

可以看到返回值val = 0x0B,即低八位非0。这时用WIFEXITED(status)(bool类型的)可以得到0,即异常,而为真表示正常退出;

3、可以组合使用:

if(WIFEXITED(status) != 0){

    printf("normally terminate val:%d",status);

}

何为正常退出?一般调用了exit(val)或者从main()函数返回就是正常,呵呵。

这下大家明白怎么判断了吧?

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值