线程池ExecutorService和CountDownLatch组合使用处理大量数据和统计时间 最近在做公司的项目数据迁移,需要把大量的数据查出来做一些逻辑处理,依靠基本是不能完全实现,还是需要我们通过代码来处理。 传统操作是查出所有数据,然后遍历处理。 为了发挥多核CPU的优势,提升处理速度,...... 言曌 11月02日 2493 7 阅读全文
线程安装的List:Collections.synchronizedList与CopyOnWriteArrayList比较 之前帮一个朋友写代码的时候,遇到一个需要遍历列表。 一、单线程:性能较差 版本一、单线程方式 Long startTime = Syste...... 言曌 08月20日 2742 5 阅读全文
线程的五大状态 Java中的线程的生命周期大体可分为5种状态。 1. 新建(NEW):新创建了一个线程对象。 2. 可运行/就绪(RUNNABLE):线程对象创建后,其他线程(比如main线程)调用了该对象的st...... 言曌 07月04日 1676 6 阅读全文
轻松掌握java读写锁(ReentrantReadWriteLock)的实现原理 原文地址:http://blog.csdn.net/yanyan19880509/article/details/52435135 前言 前面介绍了java中排它锁,共享锁的底层实现机制,本篇再进...... 言曌 03月15日 1885 6 阅读全文
Java 中 Lock 接口详解 摘要: 我们已经知道,synchronized 是Java的关键字,是Java的内置特性,在JVM层面实现了对临界资源的同步互斥访问,但 synchronized 粒度有些大,在处理实际问题时存在诸...... 言曌 03月15日 1502 7 阅读全文
基于 wait/notify 实现“生产者/消费者”模式 生产消费互相竞争,最多生产20个 package thread.test; /** * @author 言曌 * @date 2018/3/14 上午9...... 言曌 03月14日 1882 6 阅读全文
为什么 stop() 和 suspend() 方法被废除 JDK1.0定义了stop和suspend方法: 从JDK1.2开始,这两个方法都被弃用了.stop天生就不安全,而经验告诉我们呢suspend方法会经常导致死锁。 stop这个方法将终止...... 言曌 03月12日 3958 6 阅读全文