最近复习的时候看到一句 “一个线程的死掉等于整个进程的死掉” 和直觉冲突。理解中觉得一个进程下会可能存在多个线程同时工作,为什么一个线程的崩溃,会威胁到整个进程?做了一些简短的调查后,避免未来忘记进行简要记录。
结论:确实如此!进程拥有属于自己独立的地址空间,是最小的资源单位,更加安全,一个进程自己出现问题不会影响到其余进程的运行,但是进程间的切换和资源的分配,会给CPU造成更多的负担,劣于线程的特点;
线程是进程的一个分支,没有属于自己独立的地址空间,使用的是该进程的地址空间,是最小的程序运行单位,线程有自己独立的栈(stack)但是没有独立的堆(heap),整个进程内的线程使用的是该进程的堆。
进程适合完成多个独立的任务,这些任务之间不需要太多的资源共享和通信;线程通信更直接,资源也可共享,更适合用于一个任务内的不同操作,衔接关系更密切。
多机分布用进程,多核分布用线程。并行操作及效率上使用线程,需要安全性为主使用进程。
当线程操作到不属于该进程的地址空间时,为避免影响到其余进程,操作系统的保护机制会直接将该线程所属的进程崩溃。