fork()与I/O函数
来源:互联网 发布:网络聊天用语段子 编辑:程序博客网 时间:2024/05/16 18:11
今天翻书看到这个,就要分享一下
一般的,fork之后是父进程还是子进程先执行是不确定的。这取决于内核所使用的调度算法。
int glob = 6;char buf[] = "a write to stdout\n";int main(void){ int var; pid_t pid; var = 88; if(write(STDOUT_FILENO, buf, sizeof(buf)-1) != sizeof(buf) -1) err_sys("write error"); printf("before fork\n"); if( (pid = fork()) < 0) err_sys("fork error"); else if(pid == 0){ glob++; var++; }else sleep(2); printf("pid = %d, glob = %d, var = %d\n", getpid(), glob, var); exit(0);}
系统调用write是不带缓存的,因为在fork()之前调用write,所以其数据写到标准输出一次。
但是I/O库函数是带缓存的。当以交互的形式运行改程序(行缓存),只得printf()输出的行一次,因为标准输出缓存由新行符刷新。但是当标准输出重定向到一个文件时,它是全缓存,得到printf()输出行两次。原因:在fork()之前调用了printf一次,但是当调用fork时,该行数据仍在缓存中,然后在父进程数据空间复制到子进程中,该缓冲数据也复制到子进程中。在exit之前,第二个printf将其数据也添加到缓存中。当进程结束时,其缓存内容才会被写到相应的文件中。
下面运行结果:
huwang@huwang:~/demo/unix/chapter08$ ./demoa write to stdoutbefore forkpid = 16016, glob = 7, var = 89pid = 16015, glob = 6, var = 88huwang@huwang:~/demo/unix/chapter08$ ./demo > temphuwang@huwang:~/demo/unix/chapter08$ cat tempa write to stdoutbefore forkpid = 16034, glob = 7, var = 89before forkpid = 16033, glob = 6, var = 88
标准I/O提供缓存的目的就是尽可能减少使用read和write调用的数量。不同的缓冲长度,执行I/O所需的CPU时间两有很大的差异。对每个IO流进行缓存管理。一般的,驻在磁盘上的文件通常是由I/O库应用全缓存。当涉及一个终端时,典型的使用行缓存。
0 0
- fork()与I/O函数
- fork函数与I/O函数之间的交互关系
- UNIX 环境高级编程(九)—— fork 函数与 I/O 函数
- 标准I/O与Unix I/O函数整合
- fork与fork函数
- linux文件设备与I/O:C标准I/O函数与无缓冲I/O
- 标准I/O库与Unbuffered I/O(不带缓冲的I/O)函数
- I/O函数recvmsg与sendmsg
- I/O输入与输出函数
- 65-高级 I/O 函数与技术
- C语言linux I/O函数集与windows I/O 函数集
- C语言linux I/O函数集与windows I/O 函数集
- 缓冲I/O与非缓冲I/O(fopen与open系列函数区别)
- 缓冲I/O与非缓冲I/O(fopen与open系列函数区别)
- 缓冲I/O与非缓冲I/O(fopen与open系列函数区别)
- I/O多路复用——select函数与poll函数
- Linux I/O函数
- I/O函数学习
- Course Schedule
- ListView中的setOnItemClickListener参数
- UML类图符号 各种关系说明以及举例
- 互联网协议基础知识小结
- MyEclipse:DEBUG
- fork()与I/O函数
- JavaScript ---- 手势上滑下滑事件判断
- MyBatis主键生成器Jdbc3KeyGenerator(二)
- 第五周 项目3 - 括号的匹配
- 淘宝首页性能优化实践
- Thinking in java 学习笔记--chp02
- [深度学习基础] 深度学习基础及数学原理
- Linux进程实践(5) --守护进程
- HDU 5510 Bazinga(2015亚洲区沈阳站现场赛)