零基础学Java—多线程(四十九)

Posted 王同学要努力

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了零基础学Java—多线程(四十九)相关的知识,希望对你有一定的参考价值。

【零基础学Java】—多线程(四十九)

一、并发与并行

并发:指两个或多个事件在同一时间段内发生
并行:指两个或多个事件在同一时刻发生(同时发生)


二、进程和线程

🧨进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程;进程也是程序的一次执行过程,是视同运行程序的基本单位;系统运行一个程序即使一个进程从创建、运行到消亡的过程。

🧨线程:线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程,一个进程中是可以有多个线程的,这个应用程序也可以成为多线程程序。

🧨简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程

三、线程调度

分时调度:所有线程轮流使用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程序属于抢占式调度,哪个线程的优先级高,哪个线程就优先执行。同一个优先级随机选择一个执行

五、多线程原理

六、多线程内存图

以上是关于零基础学Java—多线程(四十九)的主要内容,如果未能解决你的问题,请参考以下文章

一起学Java(四十九)----- 工厂设计模式

零基础学Java—自定义异常(四十八)

零基础学Java—List集合(三十九)

零基础学Java—LinkedList集合(四十)

零基础学Java—哈希值(四十一)

零基础学Java—throw关键字(四十六)