在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
对于Java程序员而言,了解并掌握多线程是极其重要的,因为多线程在工作中的使用场景实在是太常见了。而仅仅掌握了Java中的传统多线程机制还是不够的,下面给大家介绍一下Java的线程并发库,主要包括java.util.concurrent包 、java.util.concurrent.atomic包和java.util.concurrent.lock包。

(1)java.util.concurrent 包
java.util.concurrent 包含许多线程安全、测试良好、高性能的并发构建块。不客气地说, 创建java.util.concurrent 的目的就是要实现Collection框架对数据结构所执行的并发操作。通过提供一组可靠的、高性能并发构建块,开发人员可以提高并发类的线程安全、可伸缩性、性能、可读性和可靠性,后面、我们会做介绍。如果一些类名看起来相似,可能是因为 java.util.concurrent 中的许多概念源自 Doug Lea 的util.concurrent 库 。
(2)java.util.concurrent.atomic 包
查看 atomic 包文档页下面的介绍,它可以对多线程的基本数据、数组中的基本数据和对象中的基本数据进行多线程的操作(AtomicInteger、AtomicIntegerArray、AtomicIntegerFieldUpDater…)
通过如下两个方法快速理解 atomic 包的意义:
AtomicInteger 类的 boolean compareAndSet(expectedValue, updateValue);
AtomicIntegerArray 类的 int addAndGet(int i, int delta);
顺带解释 volatile 类型的作用,需要查看 java 语言规范。volatile 修饰的变量,线程在每次使用变量的时候,都会读取变量修改后的最的值。(具有可见性)volatile 没有原子性。
(3)java.util.concurrent.lock 包
为锁和等待条件提供一个框架的接口和类,它不同于内置同步和监视器。该框架允许更灵活地使用锁和条件。本包下有三大接口,下面简单介绍下:
Lock 接口:支持那些语义不同(重入、公平等)的锁规则,可以在非阻塞式结构的上下文(包括 hand- over-hand 和锁重排算法)中使用这些规则。主要的实现是 ReentrantLock。
ReadWriteLock 接口:以类似方式定义了一些读取者可以共享而写入者独占的锁。此包只提供了一个实现,即 ReentrantReadWriteLock,因为它适用于大部分的标准用法上下文。但程序员可以创建自己的、适用于非标准要求的实现。
Condition 接口:描述了可能会与锁有关联的条件变量。这些变量在用法上与使用 Object.wait 访问的隐式监视器类似,但提供了更强大的功能。需要特别指出的是,单个 Lock 可能与多个 Condition 对象关联。为了避免兼容性问题,Condition 方法的名称与对应的 Object 版本中的不同。
Java的线程并发库就介绍到这里了,如果大家对Java的多线程感兴趣,可以上博学谷官网学习Java的相关知识点,相信可以帮助大家翻越这座技术难点的大山!
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Java开发面试题会问什么?
java开发面试题会问什么?Java开发找工作面试都会问些专业性的问题,除了简单的自我介绍,还需要介绍一些项目的整体架构,或是参与过某个模块的开发,模块的业务及设计,还有一些JAVA的专业技能的展示。
8129
2019-04-15 17:35:41
Java程序员的困境与突破
常常会有人问这样的问题:“现在学Java的人那么多,学Java是不是已经是找不到工作了?”这是一些想要学习Java的小伙伴们普遍的困扰,甚至还有些已经成为Java程序员的人也会问:“不是说当Java程序员工资高前景好吗?为什么我就找不到高薪的工作?”针对这些问题,其实都是一个答案。Java就业前景只会越来越大,哪怕再过20年,它也是热门的高薪职业之一,所以自己职业发展的问题永远都别推给行业。
7731
2019-08-01 16:51:03
Java异常处理面试题整理附答案
在Java编程语言或计算机硬件中,异常处理作为一种机制,被用于处理软件或信息系统中出现的异常状况。今天本文为大家整理了有关异常处理的常见经典面试题,并且总结了参考答案,内容包含了异常的分类、Java异常处理机制等等,相信本文一定能解决大多数人对Java中异常处理的大部分问题,有需要的朋友就赶紧收藏起来吧!
7215
2020-01-13 09:40:01
TLAB线程本地分配缓存区是什么?TLAB工作原理分析
TLAB线程本地分配缓存区是什么?工作原理分析,TLAB全称Thread Local Allocation Buffer,即线程本地分配缓存区,是一个线程专用的内存分配区域。在线程初始化时,虚拟机会为每个线程分配一块TLAB空间,只给当前线程使用。
10543
2020-03-17 15:26:25
Java开发就业前景及发展空间如何?
Java语言有广泛的行业发展前景,Java技术无处不在,无论手机软件、Java游戏开发、电脑软件等,只要使用到电子产品都有Java相关的东西,大部分企业采用Java语言开发网站。
6768
2020-04-08 11:07:05
