Java多线程 (一)—— 基本概念

一、程序、进程与线程

程序:含有指令和数据的文件,被存储在磁盘或其他的数据存储设备中,是为完成特定任务、用某种语言编写的一组指令的有序集合。即指一段静态的代码,静态对象。
进程:是具有一定独立功能的程序的运行过程,是系统进行资源分配和任务调度的一个独立单位;进程是程序的一次执行过程,或是正在运行的一个程序。是动态的过程;有它自身的产生、存在和消亡的过程。例如:正在运行中的企业微信就是一个进程。
线程:与进程相似,是一个比进程更小的执行单位。一个进程在其执行的过程中可以产生多个线程。与进程不同的是同类的多个线程共享同一块内存空间和一组系统资源。所以系统在产生一个线程,或是在各线程之间切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。
例如:我们新建一个HelloWorld.java文件,并打印出Hello world,java HelloWorld执行后,会先启动JVM,这里的JVM就是一个进程。JVM再启动一个主线程调用main方法(main方法就是主线程),同时再启动一个gc垃圾回收线程来回收垃圾和异常处理线程。从这和例子可以看出线程是一个进程的执行单元,一个进程在其执行的过程中可以产生多个线程(例子中的主线程、gc垃圾回收线程和异常处理线程)。
一个进程中的多个线程共享相同的内存单元/内存地址空间它们从同一堆中分配对象,可以访问相同的变量和对象。这就使得线程间通信更简便、高效。但多个线程操作共享的系统资源可能就会带来安全的隐患。
(隐患为到底哪个线程操作这个数据,可能一个线程正在操作这个数据,另一个线程也来操作了这个数据,具体可以配合JVM内存结构图了解,这里不做详细解读)

二、单核CPU与多核CPU

单核CPU:是一种假的多线程,因为在一个时间单元内,也只能执行一个线程的任务。同时间段内有多个线程需要CPU去运行时,CPU也只能交替去执行多个线程中的一个线程,但是由于其执行速度特别快,因此感觉不出来。例如:线程A播放音乐,线程B运行LOL游戏,CPU只能执行其中一个线程,但是由于CPU在线程A和线程B频繁切换执行,给人的感觉就是边播放音乐边玩游戏,好像A、B两个线程同时执行了,这是因为CPU执行速度特别快,人眼感觉不出来,所以说是一种假的多线程。
多核CPU:可同时执行多个线程,更好的发挥多线程的效率。

三、并发与并行

并行:指两个或多个事件在同一时刻点发生。(例如3个人同时吃馒头)
并发:指两个或多个事件在同一时间段内发生。同一时刻,多个任务交替执行,使用户看上去是在同时执行,实际从cpu操作层面上不是真正的同时执行。(例如:在1s的时间段内,0-250ms执行了任务A,250-500ms执行了任务B,500-750ms执行了任务C,750-1000ms执行了任务D,A、B、C、D任务是分时交替运行的)
区别:并发(concurrent)指的是多个程序可以同时运行的现象,更细化的是多进程可以同时运行或者多指令可以同时运行。但这不是重点,在描述并发的时候也不会去扣这种字眼是否精确,并发的重点在于它是一种现象。并发描述的是多进程同时运行的现象。但实际上,对于单核心CPU来说,同一时刻只能运行一个进程。所以,这里的"同时运行"表示的不是真的同一时刻有多个进程运行的现象,这是并行的概念,而是提供一种功能让用户看来多个程序同时运行起来了,但实际上这些程序中的进程不是一直霸占CPU的,而是执行一会停一会。所以,并发和并行的区别就很明显了。它们虽然都说是"多个进程同时运行",但是它们的"同时"不是一个概念。并行的"同时"是同一时刻可以多个进程在运行(处于running),并发的"同时"是经过上下文快速切换,使得看上去多个进程同时都在运行的现象,是一种OS欺骗用户的现象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值