程序(Program):一段静态的代码
进程(Process):正在运行的一个程序(有生命周期),作为资源分配的单位
线程(Thread):是一个程序内部执行的执行路径,作为调度执行的单位(最小单位)
进程可以细化为多个线程。(进程支持多线程)
每个线程,拥有自己独立的:栈(虚拟机栈)、程序计数器(PC)
多个线程,共享同一个进程中的结构:方法区、堆。操作的就是堆中共享的数据,但多个线程操作共享的系统资源可能就会带来安全隐患。
一个Java应用程序,至少3个线程,main()主线程,gc()垃圾回收线程,异常处理线程。
并行与并发:
并行:多个CPU同时执行多个任务。比如:多个人同时做不同的事。
并发:一个CPU(采用时间片)同时执行多个任务。比如:秒杀、多个人做同一件事
线程分为守护线程和用户线程
垃圾回收线程就是一个守护线程,主线程就是一个用户线程。
用户线程结束的时候守护线程也会跟着结束,守护线程依赖于用户线程。