进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是操作系统进行资源分配与调度的基本单位.
可以把进程简单的理解为正在操作系统中运行的一个程序.
线程(thread)是进程的一个执行单元,一个线程就是进程中一个单一顺序的控制流,进程的一个执行分支
一个进程至少有一个线程.一个进程中也可以有多个线程. 可以理解为进程包含线程
例如:一个杀毒软件是一个进程,杀毒软件可以同时进行杀毒和清理垃圾,(杀毒和清理垃圾可以理解为线程)
JVM启动时会创建一个主线程,该主线程负责执行main方法,主线程就是运行main方法的线程
Java中的线程不孤立的,线程之间存在一些联系.如果在A线程中创建了B线程,称B线程为A线程的子线程,相应的A线程就是B线程的父线程
串行(Sequential) : 所有任务逐个执行
并发(Concurrent) : 同一时间段内执行
并行(parallel) : 同一时间点
并发可以提高以事物的处理效率, 即一段时间内可以处理或者完 成更多的事情.
并行是一种更为严格,理想的并发
从硬件角度来说, 如果单核CPU,一个处理器一次只能执行一个线程的情况下,处理器可以使用时间片轮转技术,可以让CPU快速的在各个线程之间进行高速切换,对于用来来说,感觉是三个线程在同时执行. 如果是多核心CPU,可以为不同的线程分配不同的CPU内核.
创建线程的两种方式:
定义 Thread 类的子类
定义一个 Runnable 接口的实现类
这两种创建线程的方式没有本质的区别
方式一:
// 1. 继承Thread
public class MyThread extends Thread {
// 2.重写Thread类中的run方法
@Override
public void run() {
// 子线程要执行的内容
System.out.println("======我是子线程=====");
}
}
public class Test1 {
public static void main(String[] args) {
System.out.println("JVM启动main线程,main线程执行main方法");
// 创建子线程对象MyThread
MyThread myThread = new MyThread();
// 启动线程
myThread.start();
/**
* 调用线程的start()方法来启动线程,启动线程的实质就是请求JVM运行相应的线程,这个线程具体在什么时候运行由线程调度器(Scheduler)决定
* 需要注意的是:
* start()方法调用结束并不意味着子线程开始运行
* 新开启的线程会执行run()方法
* 如果开启了多个线程,start()调用的顺序并不一定就是线程启动的顺序,多线程运行结果与代码执行顺序或调用顺序无关
*/
System.out.println("main主线程以后的其他代码");
}
}
运行结果: