版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/youngyangyang04/article/details/48373467
/*************************************************************************
> File Name: 8.3.c
> Author: Xiuyang(Carl) Sun
> Mail: [email protected]
> Created Time: 2015年08月28日 星期五 23时42分34秒
************************************************************************/
#include <apue.h>
int globvar = 6;
int main(){
int var;
pid_t pid;
var = 88;
printf("before vfork\n");
if((pid = vfork())<0){
err_sys("vfork error");
}else if(pid == 0){
globvar++;
var++;
_exit(0);
}
printf("pid = %ld, glob = %d, var = %d\n",(long)getpid(),globvar,var);
exit(0);
}
如果用exit调用代替_exit调用,那么可能是标准输出关闭,是printf返回-1.
实验用下面的代码
i = printf("pid = %ld, glob = %d, var = %d\n",(long)getpid(),globvar,var);
sprintf(buf, "%d\n", i);
write(STDOUT_FILENO, buf ,strlen(buf));
/*************************************************************************
> File Name: 8.3.c
> Author: Xiuyang(Carl) Sun
> Mail: [email protected]
> Created Time: 2015年08月28日 星期五 23时42分34秒
************************************************************************/
#include <apue.h>
int globvar = 6;
int main(){
int var;
pid_t pid;
var = 88;
printf("before vfork\n");
if((pid = vfork())<0){
err_sys("vfork error");
}else if(pid == 0){
globvar++;
var++;
fclose(stdout);
exit(0);
}
int i;
char buf[10];
i = printf("pid = %ld, glob = %d, var = %d\n",(long)getpid(),globvar,var);
sprintf(buf, "%d\n",i);
write(STDOUT_FILENO, buf, strlen(buf));
exit(0);
}
修改之后,就输出-1,因为实验时我的只使用exit(0)并没有关闭标准I/O,所有再加上了fclose(stdout),假设exit关闭标准I/O流,但不关闭文件描述符STDOUT_FILENO.
有些版本的标准I/O库会关闭与标准输出相关联的文件描述符从而引起write标准输出失败,再这种情况下调用dup讲标准输出复制到另一个描述符,write则使用新复制的文件描述符.
8.4
出现这种情况就是子进程在父进程结束了还没有结束
可以使用TELL_PARENT(getppid())告诉父进程 我们做完了