任何一种编程语言,启动进程和关闭进程都是跟操作系统相关的操作,python中与操作系统打交道的话,推荐使用os模块。

os.system() 函数可以启动一个进程,执行完之后返回状态码。
os.fork() 复制一个进程,如果是子进程返回0,如果是父进程返回子进程的pid,使用这个函数的时候,建议你学习一下linux编程的知识。
os.popen 以管道的方式创建进程。
os.spawnl 也可以创建进程,并能指定环境变量。
os.kill(pid, sig) 关闭一个进程,pid是进程号,sig是信号。与fork配合使用,例如你刚才用fork创建了一个子进程,它的pid是11990, 那么调用 os.kill( 11990, signal.CTRL_BREAK_EVENT) 就以ctrl+c的方式杀死了这个进程。
另外还有一个模块multiprocessing,这个模块封装了很多创建进程和进程间通信的操作,可以让你发挥多核的威力。
进程不能单独执行,它只是资源的集合。
进程要操作CPU,必须要先创建一个线程。
所有在同一个进程里的线程,是同享同一块进程所占的内存空间。
进程中第一个线程是主线程,主线程可以创建其他线程;其他线程也可以创建线程;线程之间是平等的。
进程有父进程和子进程,独立的内存空间,唯一的标识符:pid。
启动线程比启动进程快。
运行线程和运行进程速度上是一样的,没有可比性。
线程共享内存空间,进程的内存是独立的。
父进程生成子进程,相当于复制一份内存空间,进程之间不能直接访问
创建新线程很简单,创建新进程需要对父进程进行一次复制。
一个线程可以控制和操作同级线程里的其他线程,但是进程只能操作子进程。
同一个进程里的线程之间可以直接访问。两个进程想通信必须通过一个中间代理来实现。
在 Python 中,可以使用 multiprocessing.Process.terminate() 方法来关闭某个进程。该方法会发送一个 SIGTERM 信号给指定的进程,使其终止运行。要关闭进程,需要先获取该进程的 Process 对象,在调用 terminate() 方法即可。需要注意的是,这种方式是一种粗暴的方式,不会给目标进程任何机会去清理资源和保存状态。因此,在实际应用中,需要谨慎使用,并且建议先尝试发送 SIGINT 信号,等待一段时间后再尝试发送 SIGTERM 信号。
在Python中,handle是一个通用的词,经常用于表示某个对象、资源或连接。我们可以通过handle来操作和管理这些东西。
在使用Python操作文件时,我们使用文件handles来表示文件对象。
data = f.read() # 使用handle读取文件内容
f.close() # 关闭文件handle ,释放资源
这里`f`就是文件handle,我们通过它读取和操作文件。
我们通过socket的handle表示Socket连接,并通过它来发送和接收数据。
例如用pymysql,我们通过游标cursor表示一个数据库会话:
总的来说,在Python中,通过表示资源、对象或连接的handle,可以进行相应的操作。
- 每次操作结束后,应及时关闭handle,以释放资源
- 多个handle可同时存在,无需关闭的操作的handle