天天看点

java并发面试题(二)实战

本文列出了在工作中会用到的并发编程的实战问题,大家可以一起交流下,在回复中给出答案。

如何让一段程序并发的执行,并最终汇总结果?

如何合理的配置java线程池?如cpu密集型的任务,基本线程池应该配置多大?io密集型的任务,基本线程池应该配置多大?用有界队列好还是无界队列好?任务非常多的时候,使用什么阻塞队列能获取最好的吞吐量?

如何使用阻塞队列实现一个生产者和消费者模型?请写代码。

多读少写的场景应该使用哪个并发容器,为什么使用它?比如你做了一个搜索引擎,搜索引擎每次搜索前需要判断搜索关键词是否在黑名单里,黑名单每天更新一次。

如何实现乐观锁(cas)?如何避免aba问题?

读写锁可以用于什么应用场景?

什么时候应该使用可重入锁?

什么场景下可以使用volatile替换synchronized?

如何实现一个流控程序,用于控制请求的调用次数?

可以阅读以下参考资料,知道答案后可以在回复中交流

待续