python os.fork(),有关子进程入口的疑问 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
wisefree

python os.fork(),有关子进程入口的疑问

  •  
  •   wisefree Oct 28, 2016 3456 views
    This topic created in 3471 days ago, the information mentioned may be changed or developed.

    请大家帮忙看看,>_< python3 代码如下,运行环境 ubuntu12.04 virtualbox 虚拟机

    import os print('inlet is here of main process') pid = os.fork() if (pid ==0): print('child pid is running') else: print('main pid is running') 

    主进程的入口时 import os 子进程得到了主进程的所有代码,有了自己的空间,为什么入口不是 import os ,而是从 os.fork()以下执行呢?

    附图如下: http://a3.topitme.com/9/cf/f7/1177624584b1af7cf9o.jpg

    15 replies    2016-10-29 19:20:18 +08:00
    EchoUtopia
        1
    EchoUtopia  
       Oct 28, 2016
    。。设定就这样吧,如果从头那岂不是无限fork?
    raysonx
        2
    raysonx  
       Oct 28, 2016 via Android   2
    建议楼主看一下 Unix 的 fork 系统调用。
    简单来说:操作系统这一层就是这么设计的,操作系统才不关心你的 Python 文件,那是 Python 解释器关心的东西,不在一个层次上
    sujin190
        3
    sujin190  
       Oct 28, 2016   1
    你应该去看看 linux 的 fork ,既然是 fork ,自然除了所有代码数据外还包含所有状态了,锁,文件句柄,函数调用栈
    enenaaa
        4
    enenaaa  
       Oct 28, 2016 via iPad   1
    fork 是拷贝,包括内存数据和执行环境,只能说类 linux 设计有点奇葩。
    多进程考虑用 multiprocessing 啊,这个比较方便。
    nicegoing
        5
    nicegoing  
       Oct 28, 2016 via iPhone   1
    前面都有运行结果了,把主进程的结果直接拷贝给子进程。如果子进程还去跑前面的代码岂不是傻?
    BOYPT
        6
    BOYPT  
       Oct 28, 2016
    楼主你想要的是 os.system(__FILE__)吧
    wisefree
        7
    wisefree  
    OP
       Oct 28, 2016
    @raysonx 谢谢提醒!我会去看看的
    wisefree
        8
    wisefree  
    OP
       Oct 28, 2016
    @EchoUtopia 额,其实我也是这样困惑的。。
    wisefree
        9
    wisefree  
    OP
       Oct 28, 2016
    @sujin190
    @enenaaa
    确实如此,针对 linux fork , google 了一下,
    >fork 英文意思:分支, fork 系统调用复制产生的子进程与父进程(调用进程)基本一样:代码段+数据段+堆栈段+PCB ,当前的运行环境基本一样,所以子进程在 fork 之后开始向下执行,而不会从头开始执行。
    >https://www.cnblogs.com/mickole/p/3186441.html

    以后还是用 multiprocessing>_<
    wisefree
        10
    wisefree  
    OP
       Oct 28, 2016
    @BOYPT 这个是啥,没见到过,粘贴到代码里运行不了。。。
    > NameError: name '__FILE__' is not defined
    BOYPT
        11
    BOYPT  
       Oct 28, 2016
    @wisefree 记混了,__FILE__是 PHP 的, py 的应该是__file__,当前代码文件路径
    msg7086
        12
    msg7086  
       Oct 28, 2016   1
    克隆哪来的入口。
    启动新的应用程序才是从入口继续。
    克隆的话是一份程序变成两份一模一样的,当然两个程序都会从 fork()返回了。
    firstway
        13
    firstway  
       Oct 29, 2016 via Android   2
    楼上说的对, fork 完全是动态的,就在 call fork 那里分离, OS 复制成 2 个进程,分离后都从那一点各自跑各自的。他们共享执行指令,但是是不同的执行流(也就是不同的进程),这也是为什么要通过返回值 pid 来运行不同的逻辑。
    一定要分清,他们指令完全一样的(指令是死的),执行流一般是不一样,是动态的。
    在分离之初,内存其实几乎一样的,可以想象 2 个指针指向同一块内存。随着执行流的区别, OS 会对内存进行 copy on write 的操作,慢慢内存也各种写各自的。
    wisefree
        14
    wisefree  
    OP
       Oct 29, 2016
    @msg7086
    受教了,谢谢!
    wisefree
        15
    wisefree  
    OP
       Oct 29, 2016
    @firstway
    :),感谢!
    About     Help     Advertise     Blog     API     FAQ     Solana     5144 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 45ms UTC 08:33 PVG 16:33 LAX 01:33 JFK 04:33
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86