1. IO缓冲区
cout<<"hello"<<endl;
cout<<"hello";
while(1){}
因为关联到终端的IO流对象一般都是行缓冲的,因此上述代码第一个hello会被输出出来,而第二个hello因为没有endl强制刷新,因此会留在缓冲区内等待缓冲区填满或者显式刷新缓冲区,才能输出
2. fork()子进程与IO缓冲区
cout<<"hello chk";
// cout<<flush;
pid_t pid = fork();
if(pid == 0){
cout<<flush<<"我是儿子"<<endl; // 因为缓冲区没有刷新到终端,所以子进程复制了一份缓冲区内容,
}else if(pid > 0){
cout<<flush<<"我是父亲"<<endl;
}
cout<<"ni hao shi jie";
while(1){}
输出
hello chk我是父亲
hello chk我是儿子
因为第一个输出hello chk时候,没有刷新缓冲区,因此fork()的时候,子进程也会把父进程的输出缓冲区复制一份(由于写时复制机制,在子进程刷新缓冲区之前,子进程和父进程的缓冲区应该是同一个,当子进程要用flush刷新缓冲区的时候,才单独开辟一块内存缓冲区),里边含的内容也是“hello chk”,因此下边输出两个,一个是父进程输出,一个是子进程输出
如果提前刷新,
cout<<"hello chk"<<endl;
// cout<<flush;
pid_t pid = fork();
if(pid == 0){
cout<<flush<<"我是儿子"<<endl; // 因为53行缓冲区没有刷新到终端,所以子进程复制了一份缓冲区内容,
}else if(pid > 0){
cout<<flush<<"我是父亲"<<endl;
}
cout<<"ni hao shi jie";
while(1){}
输出
hello chk
我是父亲
我是儿子
因为此时在fork之前,父进程缓冲区就已经刷新了,所以创建子进程之后子进程的输出缓冲区是没有内容的,因此只输出了一次“hello chk”