zoukankan      html  css  js  c++  java
  • 子进程和父进程关系以及缓冲区应用

    int main()
    {
    printf("abc ");
    pid_t r = fork();//子进程从fork()的下条语句开始运行,标准答案是从fork的后半部分开始运行
    if(r==0)
    {
    printf("getpid = %d ",getpid());
    printf("getppid = %d ",getppid());

    }

    if(r>0)
    {
    printf("r = %d ",r);
    printf("getpid = %d ",getpid());
    printf("getppid = %d ",getppid());

    }
    if(r==-1)
    {
    printf("error! ");
    }
    printf("123 ");


    ./getpid > 1.txt
    1.txt:
    abc
    r = 2925
    getpid = 2924
    getppid = 2349
    123
    abc
    getpid = 2925
    getppid = 1
    123

    ./getpid
    abc
    r = 2922 创建的子进程的pid
    getpid = 2921 当前进程的pid
    getppid = 2349当前进程父进程的pid
    123

    gec@ubuntu:~/shared$ getpid = 2922当前进程的pid
    getppid = 1 //init进程号,父进程死了找了一个继父init,如果用else if else,结果会不一样。
    123

    为什么1.txt多个abc?
    因为文本为全缓冲,而屏幕为行缓冲,当将执行程序的结果直接输出到屏幕时,遇到‘ ’,将结果
    强制刷新,输出到屏幕,然后将内容清空,所以父进程拷贝到子进程的代码中不含有abc,
    但输出到文本不一样,文本为全缓冲,系统会将代码全缓冲到一个缓冲区中,父进程执行代码printf
    ("abc ")后,并不会将其清空,而是将其存放到缓冲区,并copy到子进程,然后子进程运行后就会再次输出
    abc。

  • 相关阅读:
    Unix高级编程之文件权限
    gdb手册
    libev 使用
    Unix高级环境编程之fcntl函数
    设计基于锁的并发数据结构
    CPU占用分析
    atomic用法
    RESTful架构搜集
    神奇的VIM
    [转] boost:lexical_cast用法
  • 原文地址:https://www.cnblogs.com/defen/p/5210877.html
Copyright © 2011-2022 走看看