一、并发与并行
并发:指两个或多个事件在同一时间段内发生
并行:指两个或多个事件在同一时刻发生(同时发生)
二、进程和线程
🧨进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程;进程也是程序的一次执行过程,是视同运行程序的基本单位;系统运行一个程序即使一个进程从创建、运行到消亡的过程。
🧨线程:线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程,一个进程中是可以有多个线程的,这个应用程序也可以成为多线程程序。
🧨简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程
三、线程调度
分时调度:所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间
抢占式调度:优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会选择一个(线程随机性),Java使用的为抢占式调度
四、主线程
JVM
执行main
方法,main()
方法会进入到栈内存,JVM
会找操作系统开辟一条main
方法通向CPU
的执行路径,CPU
就可以通过这个路径来执行main()
方法,而这个路径有一个名字,叫main
(主)线程。
创建多线程的第一种方式:创建Thread类的子类
java.lang.Thread
:是描述线程的类,我们想要实现多线程程序,就必须继承Thread
类
实现步骤:
- 创建一个Thread类的子类
- 在Thread类的子类中重写Thread中的run方法,设置线程任务(开启线程任务)
- 创建Thread类的子类对象
- 调用Thread类中start方法,开启新的线程,执行run方法
- void start()使用该线程执行;Java虚拟机调用该线程的run方法
- 结果是两个线程并发的运行,当前线程(main线程)和另一个线程(创建的新线程,执行run方法)
- 多次启动一个线程是非法的,特别是当线程已经结束执行后,不能再重新启动
- Java程序属于抢占式调度,哪个线程的优先级高,哪个线程就优先执行。同一个优先级随机选择一个执行
五、多线程原理
六、多线程内存图