java中进程与线程的区别

王林
王林原创
2019-11-12 17:26:413027浏览

进程与线程的概念

进程(资源分配的最小单位):是一个动态概念,是竞争计算机系统资源(CPU、内存、IO等)的基本单位,是并发执行的程序在执行过程中分配和管理资源的基本单位。

线程(程序执行的最小单位):是比进程更小的独立运行的基本单位,线程也被称为轻量级进程。是CPU调度和分派的基本单位。

一个程序至少一个进程,一个进程至少一个线程。

进程与线程的区别

1、地址空间:同一进程的线程共享本进程的地址空间,而进程之间则是独立的地址空间;

2、资源拥有:同一进程内的线程共享本进程的资源,如IO、内存、CPU等,但是进程之间的资源是独立的;

3、所以多进程程序要比多线程更加健壮,多线程程序只要有一个线程死掉,整个进程就死掉;但是一个进程崩溃后,在保护模式下不会对其他进程产生影响,因为进程有自己的独立的地址空间;

4、进程切换时,消耗的资源大,效率高。所以在涉及到频繁切换时,使用线程要比进程好。如果同时进行并且又要共享某些变量的并发操作,只能用线程。

5、执行过程:进程相当于一个应用程序执行的实例,所以每个独立的进程都有一个程序运行的入口、程序顺序执行序列和程序运行出口。每个线程相当于这个应用程序(进程)的一个执行流,所以不能独立执行必须依存在应用程序(进程)之中,由应用程序提供多个线程执行控制;

6、线程是处理器调度的基本单位,但是进程不是;

7、线程和进程都可以并发执行;

优缺点

线程执行开销小,但是不利于资源管理和保护。线程适合在SMP(Symmetric Multi-Processing)机器(多CPU系统)上运行。

进程执行开销大,但是能够很好的进行资源管理和保护。

推荐教程:Java教程

以上就是java中进程与线程的区别的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。