1. 基础概念
程序:指令集和数据的集合。(静态)
进程:对程序的一次执行。(动态)
对同一个程序,执行两次,那就是两个进程。
进程是系统资源分配的基本单位
线程:一个进程中包含多个(>=1)线程。
线程是CPU调度和执行的基本单位。
多线程:真正的多线程是多个CPU同时执行多个线程(多核)
在只有一个CPU时,是通过快速切换不同的线程,来模拟多核。
实际上,在具体的一刻,只能执行一个线程。
2.概述
- 线程之间是相互独立的,有自己的内存工作空间
- main()为系统的主线程,是执行的入口
- 并发控制:解决多个线程竞争同一份资源的问题
- 线程会带来额外的开销,例如并发控制开销,CPU调度时间
3.创建线程
- 继承Thread类
- 实现Runnable接口
- 实现Callable接口
4.继承Thread类来创建线程
步骤:
- 定义一个类继承Thread类
- 重写run()方法
public class D7 extends Thread{
@Override
public void run() {
int n = 100;
for(int i=0;i<n;i++){
System.out.println("This is thread " + i);
}
}
}
- 创建该类,调用start()方法
public static void main(String[] args) {
D7 d7 = new D7();
d7.start();
int n = 100;
for(int i=0;i<n;i++){
System.out.println("This is main Thread " + i);
}
}
执行结果:
可以开出确实是交替执行了两个线程
如下图所示,调用该类的run(),就是正常的执行流程,调用start()便会多线程执行