线程之间的通信更方便,同一进程下的线程共享全局变量、静态变量等数据,而进程之间的通信需要以通信的方式(IPC)进行。不过如何处理好同步与互斥是编写多线程程序的难点。
一章:讲解Python中进程和线程的概念。主要的内容包括进程和线程的创建及管理。重点讲解了多线程环境下数据同步。
线程:进程中的一个执行单元,负责进程中的程序的运行,一个进程中至少要有一个线程。一个进程中可以有多个线程的,这个应用程序也可以称之为多线程程序。
主进程在多进程模型下通过fork(php:pcntl_fork)创建子进程,多线程模型下使用pthread_create(php:new Thread)创建子线程。下文如无特殊声明将使用进程同时表示进程/线程。
但是多进程程序更健壮,多线程程序只要有一个线程死掉,整个进程也死掉了,而一个进程死掉并不会对另外一个进程造成影响,因为进程有自己独立的地址空间。
但是,一般使用多线程而不是多进程,这是因为线程使用共享内存区域。它们不分配单独的内存区域以节省内存,并且线程之间的上下文切换比进程花费的时间更少。
多进程稳定性比多线程高,因为在多进程的情况下,一个进程崩溃不会影响其他进程,而在多线程的情况下,任何一个线程崩溃会直接导致整个进程崩溃。
对线程休眠问题头痛的读者,其实还是在用单线程的思维模式考虑问题,多数情况下我们的PC都是单CPU的,某个时间点只能有一个线程运行。所谓多线程就是多个线程交替执行就好像同时运行似的。因此,休眠当前线程可以交出CPU控制权,让其他的线程有机会运行,多个线程之间只有交替运行效率才是最高的,这就像我们开车过十字路口,只有我等等,让你先过,你再等等让他先过,才能保证最高效率,否则就会造成交通系统崩溃,对线程情况也是一样的。因此,多线程中线程的休眠是程序运行的最有效方式。
mt2.start; }}1、进程与线程进程:正在执行的程序;每个进程执行,都有一个执行顺序,该顺序是一个执行路径,或者叫一个控制单元* 一个进程可以包含多个线程;* 一个进程至少要包含一个线程线程:程序中单独顺序的控制流;是进程中独立的控制单元;* 线程本身依靠程序进行运行;* 线程是程序中的顺序控制流,只能使用分配给程序的资源和环境。单线程:程序中只存在一个线程,实际上,主方法就是一个主线程;多线程:多线程是在一个程序中运行多个任务;多线程的目的:是更好的使用CPU的资源;JavaVM 启动的时候会有一个进程java.exe;该进程中至少一个线程负责Java程序的执行,而且这个线程运行的代码存在于main方法中,该线程称之为主线程;扩展:JVM启动不止一个线程,除了执行主函数代码,还有一条路径负责垃圾回收机制的线程;