Java多线程学习(1)进程与线程

通俗解释

开个QQ,开了一个进程;开了迅雷,开了一个进程。

在QQ的这个进程里,传输文字开一个线程、传输语音开了一个线程、弹出对话框又开了一个线程。

所以运行某个软件,相当于开了一个进程。在这个软件运行的过程里(在这个进程里),多个工作支撑的完成QQ
的运行,那么这“多个工作”分别有一个线程。

所以一个进程管着多个线程。

通俗的讲:“进程是爹妈,管着众多的线程儿子”…

专业术语

首先程序是静态的指令集合,而进程是运行中的指令集合。

进程是分配资源的基本单位,而线程是独立运行和调度的基本单位。

任意时刻,一个CPU只能运行一个进程,进程获得资源后进行分配,由不同的线程来执行和协作。

  1. 进程:程序的一次执行
  2. 线程:CPU的基本调度单位

一个进程的内存空间是可以被线程共享的。

进程的内存空间一般是独立的,而线程的内存空间一般是共享的,线程间的同步是为了防止竞争(因同时修改导致数据的不一致),所以要使用互斥锁,防止多个线程同时读写某一块内存区域。

还有的内存区域只允许固定个数的线程进入,就要使用信号量,防止线程之间产生冲突。

扫描二维码关注公众号,回复: 2278607 查看本文章

互斥锁止允许一个线程进入临界区,而信号量允许多个线程同时进入临界区。

另外,与进程相比,线程更加轻量级,创建、撤销一个线程比启动新进程的开销要小得多。

猜你喜欢

转载自blog.csdn.net/lin74love/article/details/81094379