1. 定义
进程:
①具有一定独立功能的程序关于某个数据集合上的一次运行活动
②系统进行资源分配和调度的一个独立单位
线程:
①进程的一个实体,是cpu调度和分派的基本单位,它是比进程更小的能够独立运行的基本单位
②线程自己基本上不拥有系统资源,只拥有一些在运行中必不可少的资源(如程序计数器,一组寄存器和栈)
③可与同属一个进程的其他的线程共享进程所拥有的全部资源
2. 关系
线程:
① 一个线程可以创建和撤销另一个线程
②同一个进程中的多个线程之间可以并发执行 (并发. VS 并行.)
相当于进程而已言,线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列
3. 区别
进程和线程的主要差别在于它们是不同的操作系统资源管理方式。
进程:有独立的地址空间;一个进程崩溃后,在保护模式下不会对其他进程产生影响
线程:只是一个进程中的不同执行路径;其拥有自己的堆栈和局部变量,但线程没有单独的地址空间,所以多进程的程序比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程
① 一个程序至少有一个进程,一个进程至少有一个线程
②线程规划尺度小于进程,使得多线程程序的并发性高
③进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大提高了程序的运行效率
④线程在执行过程中与进程存在区别。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制
⑤从逻辑角度看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看作多个独立的应用 ,来实现进程的调度和管理以及资源分配。
4.优缺点
线程:
①执行开销小,但不利于资源的管理和保护
②适合于SMP机器上运行(多CPU)
进程:
①执行开销大,利于资源的管理和保护
②可以跨机器迁移