目录
- 进程和线程的区别?
根本区别:进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位
在开销方面:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。
所处环境:在操作系统中能同时运行多个进程(程序);而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)
内存分配方面:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。
包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。
-进程和线程的优缺点?
进程的优点:
提供了多道编程,提高计算机CPU的利用率。多道编程的理解:可以将多个进程同时加载到内存中,在操作系统的调度下,可以实现并发的执行。这样就可以提供了CPU的利用率。
进程的缺点:
-进程只能在一个时间内执行一件事,如果想执行多件事,进程就无能为力了。
-进程在执行的过程中如果堵塞,例如等待用户输入信息,整个进程就会挂起,即使进程中有些工作不依赖输入的数据,也将无法执行。
线程的优点:
-创建一个新线程的代价要比创建一个新进程小的多
-与进程之间的切换相比,线程之间的切换需要操作系统做的工作要少很多
-线程占用的资源要比进程少很多
-能充分利用多处理器的可并行数量
-在等待慢速I/O操作结束的同时,程序可执行其他的计算任务
-计算密集型应用,为了能在多处理器系统上运行,将计算分解到多个线程中实现
-I/O密集型应用,为了提高性能,将I/O操作重叠。线程可以同时等待不同的I/O操作
线程的缺点:
-性能损失
-健壮性降低
-缺乏访问控制
-编程难度提高