# 进程与线程的区别

# 定义

进程

具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位

线程

是进程中的一个实体,是被系统独立调度的基本单位。比进程更小的能独立运行的基本单位。

# 关系

  • 一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行.
  • 线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。

# 目的

  • 进程:为了使多个程序更好的并发执行,改善资源利用率、提高系统效率。
  • 线程:为了减少并发执行时所付出的时空开销,使并发粒度更细、并发性更好

# 区别

进程

  • 独立的地址空间:一个进程崩溃后,在保护模式下不会对其它进程产生影响

线程

  • 只是进程中的不同执行路径
  • 有独立的堆栈与局部变量
  • 没有单独的地址空间
  • 一个线程死掉等于整个进程死掉

总结

  • 多进程程序比多线程程序健壮
  • 进程切换时耗费资源更大,效率较差
  • 线程执行开销小,但不利于资源的管理和保护
  • 要求同时进行又要共享某些变量的并发操作,只能用线程,不能用进程。
  • 多个线程共享内存,从而极大地提高了程序的运行效率
  • 进程在执行过程中拥有独立的内存单元