2021-01-16

线程都有哪些方法

wait方法呢就是线程等待,调用这个方法之后,线程进入等待状态,只有等待通知notify或者notifyAll才会继续执行,会释放锁,释放cpu资源。

sleep线程睡眠,让当前线程休眠,此时线程处于阻塞的状态,时间到了之后,线程继续向下执行,不会释放锁,不会解除cpu占用

yield线程让步,意思是释放CPU资源,让其他线程抢夺CPU资源

join线程插队,就是让当前线程先运行,其他线程先等待

interrupt线程中断,就是中断当前线程的意思

notify唤醒线程,notifyAll唤醒所有线程

线程池的原理

线程池主要由4个部分组成,

线程池管理器:用于创建并管理线程池
工作线程:线程池中的线程
任务接口:每个任务,必须实现的接口,用于工作线程调度运行
任务队列:用于存放待处理的任务,提供一种缓冲机制

线程池做的工作主要是控制运行的线程的数量;处理过程中将任务放入队列,然后在线程创建后启动这些任务,如果线程数量超过了最大数量,超出数量的线程排队等候;等其它线程执行完毕,再从队列中取出任务来执行。他的主要特点为:线程复用;控制最大并发数;管理线程。

ConcurrentHashMap如何实现线程安全

ConcurrentHashMap是线程安全的HashMap,内部采用了的"分段锁"策略,它的主干是个Segment数组,通过继承ReentrantLock 来进行加锁。
所以每次锁住的是一个 segment,这样只要保证每个 Segment 是线程安全的,也就实现了全局的线程安全。
一个Segment就是一个子哈希表,默认有16 个 Segment。所以理论上,只要它们的操作分别分布在不同的 Segment 上,最多可以同时支持 16 个线程并发写。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值