在python线程中执行os.system()时会发生什么?
我不熟悉python线程。我试图理解从python线程调用os.system()时会发生什么。我知道线程确实共享文件描述符、堆、代码和全局变量。我还读到os.system(cmd)创建了一个新的子shell,并在那里执行提供的cmd 我的问题是,当python线程调用os.system(cmd)并且cmd执行“/test.exe input_file.dat”时,/test.exe的进程是否与python线程共享任何内容(即输入文件、地址空间、堆等)?换句话说,os.system(cmd)是否创建了一个与调用进程或线程无关的新进程 下面,我提供了我编写的python代码在python线程中执行os.system()时会发生什么?,python,linux,multithreading,system-calls,Python,Linux,Multithreading,System Calls,我不熟悉python线程。我试图理解从python线程调用os.system()时会发生什么。我知道线程确实共享文件描述符、堆、代码和全局变量。我还读到os.system(cmd)创建了一个新的子shell,并在那里执行提供的cmd 我的问题是,当python线程调用os.system(cmd)并且cmd执行“/test.exe input_file.dat”时,/test.exe的进程是否与python线程共享任何内容(即输入文件、地址空间、堆等)?换句话说,os.system(cmd)是否创
#!/usr/bin/python
import threading
import os
semaphore = threading.Semaphore(3)
def run_command(cmd):
with semaphore:
os.system(cmd)
for i in range(3):
threading.Thread(target=run_command, args=("./test.exe input_file.dat", )).start()
我找到了答案。当我们从Python线程T1执行os.system(cmd)时,新的子shell被创建为T1的子进程。因此,test.exe共享T1的地址空间(基本上是T1的父级Python代码的地址空间)。在Linux上使用pmap,可以验证我的答案 在python线程中执行os.system()时会发生什么
- 创建了一个线程。与所有线程一样,该线程与创建它的线程共享其地址空间
- 该线程调用
fork()。子进程中只存在调用
的线程;其他线程不会被复制。子进程与父进程有单独的地址空间,但内存映射在所有相同的地址 (此子进程只存在很短的时间——除非您在调试器中采取特定步骤在此处暂停进程,否则在这种状态下不会看到它,但在这种情况下,它基本上是可以的。)fork()
- 新的子进程调用
,用运行execve()
的新进程完全替换自己。子进程的地址空间被破坏,并为新进程的映像创建一个新的地址空间test.exe
- 同时,调用
的线程现在调用fork()
(或者可能调用waitpid()
)以暂停其执行,直到新进程完成。一旦发生这种情况,wait()
将返回os.system()