对程序员来说,最重要的一个门槛就是面试了,虽然常有面试造核弹,工作拧螺丝的说法,但该要的面试还是要的,这里整理了一些java中juc相关面试题,快来了解下吧。
一、juc具体是?
Java 5.0 提供了java.util.concurrent(简称JUC)包,在此包中增加了在并发编程中很常见的实用工具类,用于定义类似于编程的自定义子系统,包括线程池、异步IO和轻量级任务框架。提供可调的、灵活的线程池。还提供了设计用于多线程上下文的Collection实现等。
二、什么是CAS?
CAS(Compare-And-Swap)是一种硬件对并发的支持,针对多处理器操作而设计的处理器中的一种特殊指令,用于管理对共享数据的并发访问。
CAS 是一种无锁的非阻塞算法的实现。
CAS 包含了3个操作数:
需要读写的内存值 V
进行比较的值 A(预估值)
拟写入的新值 B(更新值)
当V的值等于A时,CAS算法通过原子方式用新值B来更新V的值,否则不会执行任何操作。
三、CAS缺点是?
1)、循环时间长,开销很大
unsafe.getAndAddInt方法执行时,有个do…while,如果CAS失败,会一直尝试。如果CAS长时间不成功,可能会给CPU带来很大的开销
2)、只能保证一个共享变量的原子操作
当对一个共享变量执行操作时,我们可以循环CAS的方式来保证原子操作;但是当多个共享变量操作时,循环CAS就无法保证操作的原子性,这个时候就可以用锁来保证原子性。
3)、引来ABA问题
四、什么是[线程安全]?
如果你的代码在多线程下执行和在单线程下执行永远都能获得一样的结果,那么