什么是进程
正在运行的程序,是系统进行资源分配的基本单位。
什么是线程
又称轻量级进程,是进程中的一条执行路径,是CPU的基本调度单位。
进程和线程的区别(重要)
- 进程是操作系统资源分配的基本单位,而线程是CPU的基本调度单位
- 一个程序运行后至少有一个进程
- 一个进程可以包括多个线程,但至少需要一个线程
- 进程间不能共享数据段地址,但同进程的线程之间可以
线程的组成
CPU时间片:操作系统为每个线程分配执行时间
运行数据(内存空间):
- 堆空间:存储引用类型对象,多线程可以共享堆中的对象
- 栈空间:存储局部变量,每个线程都拥有独立的栈
线程的逻辑代码
线程的特点
线程抢占式执行(效率高,可以防止单一线程长时间独占CPU)
单核CPU中,宏观上同时执行,微观上顺序执行
Java中如何创建线程
- 继承Thread类,重写run方法
- 实现Runnable接口
- 实现Callable接口
获取线程ID/名称
- 当继承Thread类时可以用此方法:
this.getId()
this.getName() - Thread.currentThread() 获取当前线程
Thread.currentThread().getId()
Thread.currentThread().getName()
修改线程名称
(注)一定要改在.start()启动之前修改,否则没有意义;无法修改线程ID。
线程的状态(基本状态)
还有:等待状态、阻塞状态
常见方法
线程安全问题
当多线程并发访问临界资源时,如果破坏原子操作,可能会造成数据不一致
临界资源:共享资源(同一对象),一次仅允许一个线程使用,才能保证其正确性
原子操作:不可分割的操作
如何保证线程安全性
线程通信
wait() / wait(long timeout) 等待
notify() / notifyAll(). 通知