1.进程和线程的概念
(1)进程:是资源分配的最小单位。是并发执行的程序在执行过程中分配和管理资源的基本单位;是竞争系统资源(如CPU、内存、IO等)的基本单位。
(2)线程:是程序执行的最小单位。是比进程更小的独立运行的基本单位;是CPU调度和分配资源的基本单位。
一个程序至少有一个进程,一个进程至少有一个线程。
2进程和线程的区别
(1)地址空间:同一进程内的线程共享本进程的地址空间,不同进程之间的地址空间是相互独立的。
(2)资源分配:同一进程内的线程共享本进程的资源,不同进程间资源分配是独立的。
(3)多进程程序要比多线程程序健壮。多线程程序只要有一个线程死掉,整个进程都会死掉。但是一个进程崩溃后,由于保护模式的作用,并不会对其他进程造成影响,这是由于进程都有自己独立的地址空间。
(4)进程进行切换时,资源消耗大,效率高。所以在涉及频繁切换时,使用线程要比进程好。如果同时进行并且又要共享某些变量的并发操作,只能用线程。
(5)执行过程:进程相当于应用程序的一个实例。所以每个独立的进程都有一个程序运行的入口、程序顺序执行序列以及程序运行的出口。每个线程相当于这个应用程序(进程)的执行流,所以不能独立运行,必须依存于该应用程序(进程)中,由应用程序提供多线程执行控制。
(6)线程是CPU分配调度的基本单位,但是进程不是。
(7)线程和进程都能并发执行。
(8)优缺点:线程执行开销小,但是不利于资源管理和保护。线程适合在多CPU系统中运行。
进程执行开销大,但是能够很好的进行资源管理和运行。
Java中进程和线程的区别
最新推荐文章于 2023-11-06 17:12:32 发布