logo头像
Snippet 博客主题

聊聊Java锁的那些事

昨天我们学习了HashMap相关的源码,本来打算今天写ConcurrentHashMap源码分析,但是ConcurrentHashMap涉及到一些锁的概念,所以我觉得越是底层的东西,越是要好好研究一番,今天趁此机会好好的系统学习一下。 那么今天就来聊聊Java锁的那些事情。Java为我们提供了...

GC调优基础之堆大小

调整堆大小GC调整的第一堂课是调整应用程序堆的大小。关于堆大小的调整还有更高级的话题,不过作为第一步,我们首先讨论如何设置总体堆的大小。 与其他的性能问题一样,选择堆的大小其实是一种平衡。如果分配的堆过于小,程序的大部分时间可能都消耗在GC上,没有足够的时间去运行应用程序的逻辑。但是,简单粗暴...

【【Java并发编程实战】线程池应用之Executors线程池静态工厂

今天我们来认识一下,线程池的静态工厂Executors类,平时写测试代码的时候可用一用,生产代码尽量少用。为什么说生产上尽量少用呢?这是有原因的,请耐心听彤哥讲解。 阿里的代码规约不建议使用这样的工厂类,而建议使用手动创建并管理ThreadPoolExecutor,在阿里巴巴Java开发手册中...

【Java并发编程实战】-深入ThreadPoolExecutor工作机制

为了高效的管理线程,JDK1.5版本的Doug Lea大神为我们设计了大名鼎鼎的ThreadPoolExecutor。 作为Executor框架中最核心的类-ThreadPoolExecutor,我们可以认为它是一个调度工具,为了高效执行或调度任务,我们非常有必要对该类的工作原理以及内部机制了...

【Java并发编程实战】-Java线程池基础

线程池是限制系统中执行线程的数量,并能够根据一定的策略回收线程并重复使用。JDK1.5之后加入了java.util.concurrent包,我们日常称之为J.U.C并发包,这个包对我们日常解决并发提供了非常大的帮助。 根据系统的环境情况,可以自动或手动设置线程数量,达到运行的最佳效果;少了浪费...

【Java并发编程实战】-浅谈volatile内存可见性

volatile这个关键字大家都听过,看过许多源码也用过,这个关键字备受争议,很多人基于表面理解而导致在实际开发过生中大肆误用,暴露出各式各样的问题,让人摸不着头脑,今天我们来好好理解一下volatile。 百度百科:volatile是一个类型修饰符.volatile的作用是作为指令关键字,...

【Java并发编程实战】-Java内存模型

硬件的效率与一致性计算机内部运算流程 计算机执行若干个运算任务,所有的计算任务不可能仅仅靠处理器“计算”来完成,计算器存储设备与处理器的运算速度有几个数量级的差距; 至少要与内存进行交互,如读取运算数据、存储运算结果,不能仅仅靠CPU寄存器来完成 随着计算机硬件的快速发展,任何设备的读写速度要...