linux学习笔记:关于多级fork后的scanf输入的疑惑
2010-08-09 21:33
337 查看
上一篇说道关于守护进程的通信问题,我有一个想法,就是多级fork出子进程,然后这些子进程间来通信,代码就可以缩减到一个文件里了。但是实践了下发现行不通,不是通信不行,是scanf这个函数无法正确读取。下面来几段代码看下:
1.
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
int main(int argc,char *argv[]){
if(fork()>0){
int m;
scanf("%d",&m);
printf("%d/n",m);
}else{
}
return 0;
}
在fork后的父进程里scanf,运行正常。
2。
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
int main(int argc,char *argv[]){
if(fork()>0){
exit(0);
}else{
int m;
scanf("%d",&m);
printf("%d/n",m);
}
return 0;
}
fork后在子进程里scanf,父进程直接退出,发现scanf读入错误。
3。
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
#include<sys/wait.h>
int main(int argc,char *argv[]){
if(fork()>0){
wait(0);
}else{
int m;
scanf("%d",&m);
printf("%d/n",m);
}
return 0;
}
在父进程里wait阻塞,子进程scanf,发现运行正常。
4。
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
#include<sys/wait.h>
int main(int argc,char *argv[]){
if(fork()>0){
wait(0);
}else{
if(fork()>0){
wait(0);
}else{
int m;
scanf("%d",&m);
printf("%d/n",m);
}
}
return 0;
}
在子进程里在fork出孙进程,上面的这段代码运行正常的,但是如果把子进程的wait函数去掉,scanf的读入就出错了。
好了,不举例子了,免得弄糊涂了,总结下,也就是说当我们想在fork后的子进程里让scanf正确读入时,它的这个进程组的发起进程(领头进程)必须处于wait状态(不谈init进程)。
文章有不妥之处,还望大家多多指正。
1.
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
int main(int argc,char *argv[]){
if(fork()>0){
int m;
scanf("%d",&m);
printf("%d/n",m);
}else{
}
return 0;
}
在fork后的父进程里scanf,运行正常。
2。
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
int main(int argc,char *argv[]){
if(fork()>0){
exit(0);
}else{
int m;
scanf("%d",&m);
printf("%d/n",m);
}
return 0;
}
fork后在子进程里scanf,父进程直接退出,发现scanf读入错误。
3。
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
#include<sys/wait.h>
int main(int argc,char *argv[]){
if(fork()>0){
wait(0);
}else{
int m;
scanf("%d",&m);
printf("%d/n",m);
}
return 0;
}
在父进程里wait阻塞,子进程scanf,发现运行正常。
4。
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
#include<sys/wait.h>
int main(int argc,char *argv[]){
if(fork()>0){
wait(0);
}else{
if(fork()>0){
wait(0);
}else{
int m;
scanf("%d",&m);
printf("%d/n",m);
}
}
return 0;
}
在子进程里在fork出孙进程,上面的这段代码运行正常的,但是如果把子进程的wait函数去掉,scanf的读入就出错了。
好了,不举例子了,免得弄糊涂了,总结下,也就是说当我们想在fork后的子进程里让scanf正确读入时,它的这个进程组的发起进程(领头进程)必须处于wait状态(不谈init进程)。
文章有不妥之处,还望大家多多指正。
相关文章推荐
- linux基础学习笔记-2-关于控制台的基本操作
- Linux输入子系统学习笔记
- 学习笔记:关于Linux主机将编译产生的模块导入目标板的一些基本步骤
- 关于Linux的学习笔记
- linux学习笔记—提升输入效率的方法
- [Linux C语言](学习笔记)标准输入流输出流以及错误流的重定向机制(1)
- 关于linux群集学习笔记(一)
- Linux 路由 学习笔记 之十一 输入、输出路由查找相关的接口函数
- 【妙算使用笔记】Linux学习笔记—— 浅谈关于妙算GPIO的使用
- 数据结构 学习笔记之:关于顺序栈中给结构体类型指针分配内存时,使用malloc和不使用malloc的疑惑之解惑!
- linux学习笔记 (fork && FILE && PC)
- 关于linux里pg command 命令的简单理解——学习笔记
- 关于Linux的学习笔记
- Linux学习笔记之:脚本的输入参数
- 关于*大学计算机科学与技术学院的大一学生几个关于Linux学习方面的疑惑之回复
- [Linux C语言](学习笔记)标准输入流输出流以及错误流
- Linux驱动学习笔记----------input输入子系统(基本概念与流程)
- [Linux学习笔记]标准输入输出
- 【学习笔记】关于输入缓冲区。一个不规范的字符赋值语句引发的讨论
- linux学习笔记:关于linux守护进程与终端的通信