进程与线程的区别
定义
进程
具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位
线程
是进程中的一个实体,是被系统独立调度的基本单位。比进程更小的能独立运行的基本单位。
关系
- 一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行.
- 线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。
目的
- 进程:为了使多个程序更好的并发执行,改善资源利用率、提高系统效率。
- 线程:为了减少并发执行时所付出的时空开销,使并发粒度更细、并发性更好
区别
进程
- 独立的地址空间:一个进程崩溃后,在保护模式下不会对其它进程产生影响
线程
- 只是进程中的不同执行路径
- 有独立的堆栈与局部变量
- 没有单独的地址空间
- 一个线程死掉等于整个进程死掉
总结
- 多进程程序比多线程程序健壮
- 进程切换时耗费资源更大,效率较差
- 线程执行开销小,但不利于资源的管理和保护
- 要求同时进行又要共享某些变量的并发操作,只能用线程,不能用进程。
- 多个线程共享内存,从而极大地提高了程序的运行效率
- 进程在执行过程中拥有独立的内存单元