进程与线程之间内存数据的共享问题

code
from threading import Thread
from multiprocessing import Process
import os
 
def work():
    global n
    n = 0
 
if __name__ == '__main__':
    n=100
    p=Process(target=work)
    p.start()
    p.join()
    print('',n) # 毫无疑问子进程p已经将自己的全局的n改成了0,但改的仅仅是它自己的,查看父进程的n仍然为100
 
    n = 1
    t = Thread(target=work)
    t.start()
    t.join()
    print('', n)  # 查看结果为0,因为同一进程内的线程之间共享进程内的数据
outputs
macname@MacdeMacBook-Pro py % python3 cccccc.py
主 1000
macname@MacdeMacBook-Pro py %

 

 
 
 
 
 
 
 
 
 
 
 
 
 

posted @ 2020-12-26 17:15  anobscureretreat  阅读(259)  评论(0编辑  收藏  举报