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

线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本 单位

进程和线程的关系

一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。线程是操作系 统可识别的最小执行和调度单位

资源分配给进程,同一进程的所有线程共享该进程的所有资源。 同一进程中的多个线程共享代 码段(代码和常量),数据段(全局变量和静态变量),扩展段(堆存储)。但是每个线程拥有自己的栈段,栈段又叫运行时段,用来存放所有局部变量和临时变量

处理机分给线程,即真正在处理机上运行的是线程

线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步

进程与线程的区别

进程有自己的独立地址空间,线程没有

进程是资源分配的最小单位,线程是CPU调度的最小单位

进程和线程通信方式不同(线程之间的通信比较方便。同一进程下的线程共享数据(比如全局变 量,静态变量),通过这些数据来通信不仅快捷而且方便,当然如何处理好这些访问的同步与 互斥正是编写多线程程序的难点。而进程之间的通信只能通过进程通信的方式进行。)

进程上下文切换开销大,线程开销小

一个进程挂掉了不会影响其他进程,而线程挂掉了会影响其他线程

对进程进程操作一般开销都比较大,对线程开销就小了