一个fork的面试题
来源:互联网 发布:口腔医学专升本知乎 编辑:程序博客网 时间:2024/06/06 04:04
题目:
请问下面的程序一共输出多少个”-“
#include<stdio.h>#inlcude<unistd.h>int main(){ int i; for(i =0;i<2;i++) { fork(); printf("-"); }return 0;}
可能开始的时候大家都以为会输出6个”-“,但是结果输出了8个”-“.
要弄明白这个题,还是先从fork()调用开始
1:fork()系统调用是Unix下以自身进程创建子进程的系统调用,一次调用,两次返回,如果返回时0,则是子进程,如果返回值>0,则是父进程(返回值是子进程的pid),
2:在fork()的调用过程中,整个父进程空间都会被子进程继承,包括指令,变量值,程序调用栈,环境变量,缓冲区,等等.
第一种:不带”\n”
我们再通过图形来分析下:
第二种:加上”\n”
,输出6个”-“.为什么呢?
因为程序遇到”\n”或者是EOF,或者缓冲区满,或是文件描述符关闭,或是主动flush,或是程序退出,就会把数据刷出缓冲区,需要注意的是,标准呼出是行缓冲,所以遇到”\n”的时候回刷出缓冲区,当然可以使用setvbuf来设置缓冲区大小,或者是fflush刷缓存.
本文参考http://coolshell.cn/articles/7965.html
阅读全文
0 0
- 一个 fork 的面试题
- 一个 fork 的面试题
- 一个 fork 的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 一个fork的面试题
- 202. Happy Number
- 73前序遍历和中序遍历树构造二叉树
- string实现C++
- 自己封装一个类借助实现数据库加载及夜间模式
- matlab之simulink学习(1、搭建一个简单系统)
- 一个fork的面试题
- java生成PDF文件
- tomcat webapps 目录下web工程只有目录,没有class文件
- jstree -- 使用JSON 数据组装成树
- 剑指offer-最小的K个数
- C++操作redis数据库
- java基础篇《7》--面向对象《2》
- 【剑指offer】面试题 21:调整数组顺序使奇数位于偶数前面
- 嵌入式每日学习心得2017.07.17