Chinaunix

标题: 一个关于vfork的问题 [打印本页]

作者: 转瞬繁华    时间: 2010-12-25 13:04
标题: 一个关于vfork的问题
vfork后,子进程在父进程的地址空间中运行,父进程阻塞直到子进程调用exec或_exit。那么当子进程在父进程的地址空间中运行,并且执行了close(STDOUT_FILENO)后,正常退出。这时,父进程继续运行,并调用输出语句,例如:printf("hello world!\n");  这个标准输出已经被子进程关闭了,为什么我的程序还能够输出结果呢? 望高手解答!
作者: linyunxian    时间: 2010-12-25 22:57
vfork后,子进程在父进程的地址空间中运行,父进程阻塞直到子进程调用exec或_exit。那么当子进程在父进程的 ...
转瞬繁华 发表于 2010-12-25 13:04



    vfork 之后两者的栈还是不一样的。并不是共用的,跟clone() 一样。
作者: kouu    时间: 2010-12-27 00:01
没错,子进程在父进程的地址空间中运行(包括使用相同的栈),但是这并不代表子进程要像pthread_create创建的线程那样,共享父进程的打开文件集。
子进程会拥有自己的打开文件集,所以在子进程里面close(1),对父进程是没有影响的。毕竟vfork创建的是进程,而不是线程。
作者: 脚丫子1987    时间: 2010-12-27 10:28
没错,子进程在父进程的地址空间中运行(包括使用相同的栈),但是这并不代表子进程要像pthread_create创建 ...
kouu 发表于 2010-12-27 00:01



   正解再次
作者: luoyan_xy    时间: 2010-12-27 10:42
没错,子进程在父进程的地址空间中运行(包括使用相同的栈),但是这并不代表子进程要像pthread_create创建 ...
kouu 发表于 2010-12-27 00:01



   
    学习了。。。
作者: lwwworkspace    时间: 2011-01-07 08:56
昨天我也提了这个问题,原来已经有人问过了。呵呵,学习了。{:3_186:}




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2