Java多线程

多线程理解:

应用软件中可互相独立同时运行的功能

总结:

并发:同一时刻多个指令在单个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虚拟机中没有定义 运行 状态,因此为六个状态

线程池

原理:

方法

自定义线程池

拒绝策略

代码实现:

线程池大小

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值