线程都有哪些方法
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 个线程并发写。