什么是多线程(Java.Thread)
- 线程就是独立执行的路径
- 在程序运行时即使没有自己创建线程后台也会有多个线程如:主线程(Main)、垃圾回收线程(GC)
- main()称之为主线程,为系统的入口,用于执行整个程序
- 在一个进程中如果开辟了多个线程,线程的运行是由调度器安排调度的,调度器是与操作系统紧密相关的,先后顺序是不能人为干涉的
- 对同一份资源操作时,会存在资源抢夺的问题需要加入并发控制
- 线程会带来额外的开销,如CPU调度时间,并发控制开销
- 每个线程在自己的工作内存交互,内存控制不当会造成数据不一致
Process(进程)和 Thread(线程)
- 程序是指令和数据的有序集合其本身没有运行的含义,是一个静态的概念。
- 进程则是执行程序的一次执行过程,使用动态的概念是系统资源分配的单位。
- 一个进程可以包含若干个线程,一个进程中至少包含一个线程,线程是CPU调度和执行的单位。
线程的创建
Thread class:继承Thread创建多线程
/**
* 继承Thread 并重写run()方法实现多线程开启
*/
public class CreateThread extends Thread {
//当多线程的start()方法被调用时会执行重写后的run()方法
@Override
public void run() {
for (int i = 0; i < 2000; i++) {
System.out.println("多线程执行中-----》"+i);
}
}
/**
* 主线程中开启多线程
* @param args
*/
public static void main(String[] args) {
//实例化多线程对象
CreateThread createThread = new CreateThread();
//开启多线程
createThread.start();
for (int i = 0; i < 2000; i++) {
System.out.println("主线程执行中-----》"+i);
}
}
}
Runnable 接口: 实现 Runnable 接口创建多线程 推荐使用一个对象可以被多个线程使用
/**
* 实现 Runnable 接口开启多线程
*/
public class CreateThread2 implements Runnable {
@Override
public void run() {
for (int i = 0; i < 1000; i++) {
System.out.println("多线程执行中-----》"+i);
}
}
/**
* 主线程中开启多线程
* @param args
*/
public static void main(String[] args) {
//实例化多线程对象
CreateThread2 createThread = new CreateThread2();
//创建线程对象,并将多线程对象传入,开启多线程
new Thread(createThread).start();
for (int i = 0; i < 1000; i++) {
System.out.println("主线程执行中-----》"+i);
}
}
}
Callable 接口: