多线程
多线程
并发:指两个或多个事件在在同一时间端内发生(交替执行)。
并行:指两个或多个事件在同一时刻发生(同时执行)。
进程
进程︰是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程;进程也是程序的一次执行过程,是系统运行程序的基本单位;系统运行一个程序即是一个进程从创建、运行到消亡的过程。
线程︰线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程。一个进程中是可以有多个线程的,这个应用程序也可以称之为多线程程序。
简而言之∶一个程序运行后至少有一个进程,一个进程中可以包含多个线程我们可以再电脑底部任务栏,右键---->打开任务管理器,可以查看当前任务的进程︰
线程调度:
- 分时调度
所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU 的时间。 - ·抢占式调度
I优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会随机选择一个(线程随机性),Java使用的为抢占式调度。
创建线程类
主线程:执行主方法(main)的线程
单线程:java程序中只有一个线程,执行从main方法开始,从上到下一次执行。
实现步骤:
- 创建一个Thread类的子类
- Thread类的子类中重写Thread类中的run方法,设置线程任务(开启线程要做什么?)
- 创建Thread类的子类对象
- 调用Thread类中的方法start方法,开启新的线程,执行run方法
void start()使该线程开始执行; Java虚拟机调用该线程的run方法。
结果是两个线程并发地运行﹔当前线程(main线程)和另一个线程《创建的新线程,执行其run方法)。多次启动一个线程是非法的。特别是当线程已经结束执行后,不能再重新启动。
java程序属于抢占式调度,那个线程的优先级高,那个线程优先执行;同一个优先级,随机选择一个执行
//1.创建一个Thread类的子类
public class Mythread extends Thread {
//2.Thread类的子类中重写Thread类中的run方法,设置线程任务(开启线程要做什么
@Override
public void run(){
for (int i = 0; i <20 ; i++) {
System.out.println("run"+i);
}
}
}
public class Demo01Thread {
public static void main(String[] args) {
//3. 创建Thread类的子类对象
Mythread mt = new Mythread();
//4. 调用Thread类中的方法start方法,开启新的线程,执行run方法
mt.start();
for (int i = 0; i <20 ; i++) {
System.out.println("main:"+i);
}
}
}//每次执行结果都不一样
/*main:0
run0
main:1
run1
main:2
run2
main:3
run3
main:4
run4*/
浙公网安备 33010602011771号