coding……
但行好事 莫问前程

Java编程拾遗 第2页

Java编程拾遗『并发容器——CopyOnWrite』

zhuoli阅读(715)评论(0)赞(1)

从本片文章开始我们来介绍并发容器类,之前的文章介绍过普通容器类,比如ArrayList、LinkedList等。但是这些容器都有个问题,就是非线程安全,多线程并发写,会存在线程安全问题,所以Java提供了并发容器类来解决普通容器类的线程安全...

Java编程拾遗『AQS』-Zhuoli's Blog

Java编程拾遗『AQS』

zhuoli阅读(896)评论(0)赞(1)

上篇文章讲了Java中显式锁Lock和ReadWriteLock的概念及简单使用示例,本篇文章重点来看一下Java中显式锁的底层实现。在看这部分代码时,我任务比较好理解的方式是带着问题去看源码。对于显式锁,我们可能会有以下问题: 问题1:显...

Java编程拾遗『显式锁』

zhuoli阅读(2123)评论(0)赞(1)

在之前讲线程同步时,介绍了synchronized的锁的使用及底层原理,也介绍了synchronized锁的一些使用局限,本篇文章来介绍一下Java中提供的另一种线程同步机制——显式锁。Java并发包中的显式锁接口和类位于包java.uti...

Java编程拾遗『原子变量』

zhuoli阅读(734)评论(0)赞(1)

本篇文章我们来讲java.util.concurrent包下的原子变量,原子变量的引入主要是为了解决普通变量(int、Integer、Long等)修改操作不是原子的,进而导致必须使用同步机制才能保证安全更新的问题。举个例子: Counter...

Java编程拾遗『线程中断』

zhuoli阅读(766)评论(0)赞(1)

之前的文章,我们已经介绍了线程的概念、使用、同步及线程协作,本篇文章来重点讲一下Java中如何取消或关闭一个线程。 1. 线程取消/关闭的场景 我们知道,通过线程的start方法启动一个线程后,线程开始执行run方法,run方法运行结束后线...

Java编程拾遗『线程协作』

zhuoli阅读(901)评论(0)赞(1)

之前用了两篇文章介绍了多个线程竞争资源的解决方案synchronized,但其实多个线程之间除了竞争资源之外,还有相互协作。比如: 生产者/消费者模式:这是一种常见的协作模式,生产者线程和消费者线程通过共享队列进行协作,生产者将数据或任务放...

Java编程拾遗『synchronized原理』-Zhuoli's Blog

Java编程拾遗『synchronized原理』

zhuoli阅读(762)评论(0)赞(3)

上篇文章简单介绍了一下synchronized的使用,以及对象锁和类锁的概念,本篇文章就来介绍一下synchronized的底层原理。 上篇文章也提到,我们对synchronized的印象是重量级锁,使用效率低下,导致我们一般在使用sync...

Java编程拾遗『synchronized使用』

zhuoli阅读(768)评论(0)赞(3)

从接触Java多线程第一刻起,我们就被告知使用多线程编程一定要注意线程安全问题。而一般的教材中都会首先给出解决线程安全问题的“万金油”——关键字synchronized,它可以保证同一时刻只有一个线程在访问其修饰的代码。但是同时,一般教程中...

Java编程拾遗『线程的使用』-Zhuoli's Blog

Java编程拾遗『线程的使用』

zhuoli阅读(924)评论(0)赞(2)

上篇文章讲了一些关于并发编程的一些基本概念,也简单提到Java中线程的创建方式,本篇文章将详细介绍一下Java中线程使用的相关细节。 1. 创建线程 如果程序中只有一条执行流,程序从main方法的第一条语句逐条执行直到结束。如果在main线...