多线程理解:
应用软件中可互相独立同时运行的功能
总结:
并发:同一时刻多个指令在单个CPU交替执行
并行:同一时刻多个指令在多个CPU同时执行
多线程的实现方式 :
方式一:继承Thread类
创建Thread类对象即可创建一个线程
继承以后重写run方法,执行语句写在run方法里即可
开启线程:用多线程的对象调用start方法开启,不能直接调用run方法
方式二:实现Runnable接口
方式三:实现callable与future接口
特点:可以获取多线程运行的结果
总结:
写法
Thread中常见成员方法:
线程优先级
优先级:1-10,默认为5
设置优先级:直接调用setPriority
守护线程
setDaemon(true)
出让线程
插入线程
线程的生命周期
线程的安全问题
同步代码块:
把操作共享数据的代码块锁起来
书写同步代码块:
1、循环不能写在锁里面,synchronized必须卸写在循环里面,否则一个线程会一直运行直到结束
2、synchronized的锁对象必须是唯一的
锁对象一般用当前类名的字节码文件对象:类名.class
同步方法:
把synchronized关键字加在方法上
lock锁
try...catch...finally,finally后的代码块一定会执行,可以将lock锁解开的代码写在finally里面
死锁:
等待唤醒机制:
线程调用wait方法执行等待,其他线程抢占CPU,随后唤醒wait线程
消费者等待
生产者等待
常见方法
消费者等待唤醒机制代码实现:
中间控制类:
消费者代码实现:
生产者代码实现:
阻塞队列实现等待唤醒机制:
阻塞队列的继承结构
代码实现:
生产者和消费者必须使用同一个阻塞队列
阻塞队列定义在测试类中,在创建对象时再把阻塞队列传给生产者和消费者
多线程的六种状态:
Java虚拟机中没有定义 运行 状态,因此为六个状态
线程池
原理: