Rumah  >  Artikel  >  Java  >  java中进程与线程的区别

java中进程与线程的区别

王林
王林asal
2019-11-12 17:26:413737semak imbas

java中进程与线程的区别

进程与线程的概念

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

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

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

进程与线程的区别

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

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

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

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

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

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

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

优缺点

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

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

推荐教程:Java教程

Atas ialah kandungan terperinci java中进程与线程的区别. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:java中的反射如何理解Artikel seterusnya:java中怎么定义函数