基本信息
- 作者: 汪文君 方腾飞 魏鹏 程晓明 Brian Goetz Tim Peierls
- 译者: 童云兰
- 丛书名: Java核心技术系列
- 出版社:机械工业出版社
- ISBN:9782007071059
- 上架时间:2020-7-7
- 出版日期:2020 年6月
- 开本:16开
- 页码:701
- 版次:1-1
- 所属分类:计算机 > 软件与程序设计 > JAVA(J#) > Java

编辑推荐
---------------------------Java并发编程的艺术---------------------------
阿里系和1号店资深技术专家撰写,Java并发编程领域的扛鼎之作
内容在InfoQ等社群得到高度认可,从JDK源码、JVM、CPU等多角度全面剖析与讲解Java并发编程的框架、原理和核心技术
---------------------------Java并发编程实战---------------------------
第16届Jolt大奖提名图书
Java并发编程必读佳作
深入浅出地介绍了java线程和并发
一本完美的java并发参考手册
内容简介
计算机书籍
---------------------------Java高并发编程详解:深入理解并发核心库---------------------------
本书共包含四大部分,其中,第一部分(第1章)详细介绍了JMH(Java Micro benchmark Harness)基准测试工具的使用细节。该工具是由Oracle JVM开发团队相关成员开发的,借助它,开发者将能足够了解自己所编写的程序代码,以及程序在运行期的精确性能表现。在本书的其他章节对API之间的性能进行对比时,主要也是依赖于该工具,因此在学习本书的其他章节时,最好能够掌握该部分内容,强烈推荐开发者将JMH纳入自己日常的“兵器库”中,以便能够随时随地进行利用。
第二部分主要围绕Java并发包进行展开,涉及的内容包括Java的原子类型及其底层原理(第2章);Java的并发工具集(第3章),其中还穿插了Google Guava的部分内容;Java的并发容器(第4章),包括阻塞队列BlockingQueue和并发容器等内容;Java的ExecutorService(第5章),以及Future家族成员的详解。
第三部分(第6章),主要介绍自Java 8 引入的Stream,并且重点解释了具备高并发能力的并行流原理,以及如何自定义并行流等相关内容。
第四部分(第7章),深入讲解Metrics,它作为一个比较小巧的度量工具集,目前已经成为事实上的度量标准,在很多开源软件、框架和平台中都能看到对它的使用,比如Apache的Kafka、Spark、Storm、Spring Cloud等都是使用Metrics作为系统运行性能指标收集的手段。
---------------------------Java高并发编程详解:多线程与架构设计---------------------------
本书主要包含四个部分:
部分主要阐述Thread的基础知识,详细介绍线程的API使用、线程安全、线程间数据通信,以及如何保护共享资源等内容,它是深入学习多线程内容的基础。
第二部分引入了ClassLoader,这是因为ClassLoader与线程不无关系,我们可以通过synchronized关键字,或者Lock等显式锁的方式在代码的编写阶段对共享资源进行数据一致性保护,那么一个Class在完成初始化的整个过程到后在方法区(JDK8 以后在元数据空间)其数据结构是怎样确保数据一致性的呢?这就需要对ClassLoader有一个比较全面的认识和了解。
第三部分详细、深入地介绍volatile关键字的语义,volatile关键字在Java中非常重要,可以说它奠定了Java核心并发包的高效运行,在这一部分中,我们通过实例展示了如何使用volatile关键字以及非常详细地介绍了Java内存模型等知识。
本书的第四部分,站在程序架构设计的角度深入讲解了如何设计高效灵活的多线程应用程序,这一部分长达15个章节,其重要程度可见一斑。
作译者
---------------------------Java高并发编程详解:多线程与架构设计---------------------------
汪文君
汪文君,某数据服务中心技术经理、技术专家,目前专注于实时数据data pipeline平台的构建与架构,曾有7年多的移动通讯工作经验,以及移动互联网、云计算和B2C电子商务平台的开发架构经验,热衷于技术分享、技术细节锤炼。目前已录制10余套技术视频,在互联网上广泛传播。
---------------------------Java并发编程的艺术---------------------------
方腾飞(花名清英,英文名Kiral)
蚂蚁金服团技术专家,从事Java开发近10年。 5年以上的团队管理、项目管理和敏捷开发经验,崇尚团队合作。曾参与CMS、电子海图、SOC、ITIL、电子商务网站和信贷管理系统等项目。目前在蚂蚁金服网商银行贷款管理团队负责数据采集平台开发工作。与同事合作开发了tala code Review插件,深受阿里数千名工程师拥趸,并开发过开源工具jdbcutil (https://github.com/kiral/utils)。创办了并发编程网(http://ifeve.com),组织翻译了百余篇国外优秀技术文章,并曾为InfoQ撰写“聊聊并发”专栏,在《程序员》杂志撰写敏捷实践系列文章,曾用博客http://kiral.javaeye.com。
魏鹏
阿里巴巴集团技术专家,在阿里巴巴中国网站技术部工作多年,曾担任中国网站交易平台架构师,主导了交易系统服务化工作,设计实现的数据迁移系统高效地完成了阿里巴巴中国网站交易数据到阿里巴巴集团的迁移工作。目前在阿里巴巴共享业务事业部从事Java应用容器Pandora和服务框架HSF的相关工作,其中Java应用容器Pandora是阿里巴巴中间件运行的基础,而服务框架HSF则是阿里巴巴集团实现服务化的主要解决方案,二者在阿里巴巴拥有最为广泛的使用量。个人平时喜欢阅读技术书籍,翻译一些国外优秀文档,喜欢总结、乐于分享,对Java应用容器、多线程编程以及分布式系统感兴趣。
程晓明
1号店资深架构师,从事1号店交易平台系统的开发,技术上关注并发与NIO。因5年前遇到的一个线上故障,解决过程中对Java并发编程产生了浓厚的兴趣,从此开始了漫长的探索之旅:从底层实现机制、内存模型到Java同步.纵观我自己对Java并发的学习过程,是一个从高层到底层再到高层的一个反复迭代的过程,我估计很多读者的学习过程应该与我类似。文章多见诸《IBM deveIOperWorks》、InfOQ和《程序员》杂志。
目录
---------------------------Java高并发编程详解:深入理解并发核心库---------------------------
推荐序一
推荐序二
推荐序三
推荐序四
前 言
第1章 JMH 1
1.1 JMH简介 1
1.2 JMH快速入门 1
1.2.1 用main方法进行测试 1
1.2.2 用JMH进行微基准测试 3
1.3 JMH的基本用法 6
1.3.1 @Benchmark标记基准测试方法 7
1.3.2 Warmup以及Measurement 8
1.3.3 四大BenchmarkMode 10
译者序
---------------------------Java并发编程实战---------------------------
并发编程是Java语言的重要特性之一,在Java平台上提供了许多基本的并发功能来辅助开发多线程应用程序。然而,这些相对底层的并发功能与上层应用程序的并发语义之间并不存在一种简单而直观的映射关系。因此,如何在Java并发应用程序中正确且高效地使用这些功能就成了Java开发人员的关注重点。
本书正是为了解决这个问题而写的。书中采用循序渐进的讲解方式,从并发编程的基本理论入手,逐步介绍了在设计Java并发程序时各种重要的设计原则、设计模式以及思维模式,同时辅以丰富的示例代码作为对照和补充,使得开发人员能够更快地领悟Java并发编程的要领,围绕着Java平台的基础并发功能快速地构建大规模的并发应用程序。
全书内容由浅入深,共分为四个部分。第一部分介绍了Java并发编程的基础理论,包括线程安全性与状态对象的基础知识,如何构造线程安全的类并将多个小型的线程安全类构建成更大型的线程安全类,以及Java平台库中的一些基础并发模块;第二部分介绍了并发应用程序的构造理论,包括应用程序中并行语义的分解及其与逻辑任务的映射,任务的取消与关闭等行为的实现,以及Java线程池中的一些高级功能,此外还介绍了如何提高GUI应用程序的响应性;第三部分介绍了并发编程的性能调优,包括如何避免活跃性问题,如何提高并发代码的性能和可伸缩性以获得理想的性能,以及在测试并发代码正确性和性能时的一些实用技术;第四部分介绍了Java并发编程中的一些高级主题,包括显式锁、原子变量、非阻塞算法以及如何开发自定义的同步工具类等。
本书的特点在于注重阐述并发技术背后的理论知识,对于每种技术的介绍不仅使读者能做到“知其然”,更能做到“知其所以然”。对于希望深入研究和探索Java并发编程的读者来说,本书是非常合适的。
参与本书翻译工作的还有李杨、吴汉平、徐光景、童胜汉、陈军、胡凯、刘红、张玮、陈红、李斌、李勇涛、王海涛、周云波、彭敏才、张世锋、朱介秋、宗敬、李静、叶锦、高波、熊莉、程凤、陈娟、胡世娟、董敏、谢路阳、冯卓、李志勇、胡欢、王进等。由于译者的时间和水平有限,翻译中的疏漏和错误在所难免,还望读者和同行不吝指正。
童云兰
2011年11月于武汉
前言
---------------------------Java高并发编程详解:深入理解并发核心库---------------------------
为什么写这本书
在我的第一本书《Java高并发编程详解:多线程与架构设计》出版之后,我随即开始了第二本书《Java高并发编程详解:深入理解并发核心库》的写作。这本书作为第一本书的延续,主要内容将围绕Java并发包的使用场景展开;同时还增加了JMH基准测试工具的内容(目前,最新的JDK版本中已经引入了该工具,并作为标准库之一发布);引入了Java 8 Stream的相关内容,尤其是还分析了与高并发相关的并行流;在本书的最后还介绍了性能度量工具Metrics(该类库目前已经成为业界实质上的度量标准,很多开源系统、商业软件中都会采用它)。
如果说我写作第一本书只是一次偶然性的尝试,那么这本书的写作则是一次必然性的使命,是对读者和出版社的一个交代与承诺。为了使得Java高并发编程的相关内容尽可能系统化和完善,必须完成对并发包的介绍。这里,我要向伟大的Doug Lea大师致敬,由于他孜孜不倦的努力、精益求精的敬业态度, Java程序员才能以较低的成本和相对安全的方式来处理非常复杂的高并发多线程场景。
本书中的所有内容都来源于我的网络视频课程。每一套课程推出后都在交流群中引起热烈讨论,我将这些讨论、学习者提出的疑惑以及自己对内容的重新思考全部融入本书中,以使本书中所涉及的知识点尽可能完善与成熟。
读者对象
计算机相关专业的在校学生
Java开发工程师
从事Java系统架构的架构师
使用Java作为开发语言的公司与组织
开设Java课程的专业院校
开设Java课程的培训机构
如何阅读本书
本书共7章,逻辑上可分为四部分。第一部分(第1章)详细介绍了JMH(Java Micro benchmark Harness)基准测试工具的使用细节。该工具是由Oracle JVM开发团队相关成员开发的,借助它,开发者将能足够了解自己所编写的程序代码,以及程序在运行期的精确性能表现。在本书的其他章节中,我们对API之间的性能进行对比时主要也是依赖于该工具,因此在学习本书的其他章节之前,最好能够先掌握该部分内容。笔者在此强烈推荐开发者将JMH纳入自己日常的“兵器库”中,以便随时随地使用。
第二部分(第2~5章)主要围绕Java并发包进行展开,内容包括:Java的原子类型及其底层原理(第2章);Java的并发工具集(第3章),其中还穿插了Google Guava的部分内容;Java的并发容器(第4章),包括阻塞队列BlockingQueue和并发容器等内容;Java的ExecutorService(第5章),以及Future家族成员的详解。
序言
---------------------------Java高并发编程详解:多线程与架构设计---------------------------
推荐序一
首先恭喜汪文君老师终于出书了,可喜可贺!汪文君老师一直是我敬佩和学习的楷模。十年之前,我在公司认识了新来的长发少年汪文君同学,至今依然记得文君他对人热情,对于工作、生活中接触的各种事物都充满了好奇心,总是在热情高涨地学习新技术,他每天晚上都会拿出时间学习,很多节假日也都抽出专门的时间来学习和编程。后来听说汪文君老师在电信、医疗、金融等多个行业从事架构设计、技术指导、编程等工作,经验非常丰富。其间还进行过创业,至今依然对架构设计、编程充满了热情,持续学习,持续成长,不仅仅自己学习实践,还录制了众多的视频传播技术与经验,根据自己的经历与心得进一步积累成书,是技术从业者中的佼佼者。
编程技术作为IT领域的关键技术,正在加速影响着越来越多行业的信息革命。IT技术不仅仅引发了众多世界性的产品创新和技术革命,同时也引发了众多行业的变革,随着“互联网+”等的驱动,传统行业也正在加速技术革命带来的技术升级与产业升级。IT技术正在加速改变我们的生活方式、沟通方式、学习方式、思维模式,涉及我们工作、学习、生活的方方面面,技术革新的力量成为了驱动经济变革与增长的最有效的引擎之一。
Java技术自1990年由James Gosling 、 Mike Sheridan 、 Sun 首席科学家 Bill Joy 等创建以来,在企业级应用、互联网应用、移动互联网应用等开发领域成为独一无二的霸主级语言,长盛不衰,形成了巨无霸的生态系统;其不仅仅是从业者的工具,也是学习深究的对象,而且一直都在不断地演进和重生。Java创建时的宣言“一次编译、到处执行”(write once,run anywhere)将Java带给了所有的编程者。下面就来简单回顾一下Java的重大历程。
1994年,“Java”之名正式诞生,Java 1.0a版本开始提供下载。
1996年1月,第一个 JDK——JDK1.0 诞生。
1997年2月18 日,JDK1.1 发布。
1998年12月8日,Java 2企业平台 J2EE 发布。
1999年6月,SUN公司发布 Java 的三个版本:标准版(J2SE)、企业版(J2EE)和微型版(J2ME)。
2004年9月30日18:00时,J2SE1.5发布,成为Java语言发展史上的又一里程碑。为了表示该版本的重要性,J2SE1.5更名为Java SE 5.0。
2005年6月,JavaOne 大会召开,Sun公司公开 Java SE 6。此时,Java的各种版本已经更名,以取消其中的数字“2”:J2EE 更名为Java EE,J2SE更名为Java SE,J2ME更名为Java ME。
2006年12月,Sun公司发布JRE6.0。
2009年4月20日,Oracle公司以每股 9.50 美元,74 亿美元的总额收购Sun公司。
2009年12月,Sun公司发布 Java EE 6。
媒体评论
---------------------------Java高并发编程详解:深入理解并发核心库---------------------------
本书的主要内容和特色:
由浅入深、循序渐进地介绍Java高并发核心库的精髓,帮助读者掌握相关内容的技术细节。
内容讲解以真实问题为导向,层层递进,环环紧扣,详细阐述每一个解决方案的来龙去脉。
大量的实际案例,原理剖析和实战代码相结合,让读者能够更加清晰深入地理解每一个技术细节的用法和实用技巧。
详细介绍Java微基准测试工具集JMH与平台级性能指标数据度量工具Metrics的使用方法,帮助读者快速开发出高效、健壮的并发应用程序。
---------------------------Java高并发编程详解:多线程与架构设计---------------------------
汪文君老师一直是我敬佩和学习的楷模。十年之前,我在公司认识了新来的长发少年汪文君同学,至今依然记得文君他对人热情,对于工作、生活中接触的各种事物都充满了好奇心,总是在热情高涨地学习新技术,他每天晚上都会拿出时间学习,很多节假日也都抽出专门的时间来学习和编程。本书围绕Java编程中多线程编程的基础与应用设计分为四个部分来展开讲解,包括多线程技术知识、Java ClassLoader、深入理解volatile关键字、多线程设计架构模式。通过这本书的学习,我们能够更全面地拓展自己的编程能力,更进一步地充实编程设计和架构设计的系统性思维。
——东软集团移动互联网事业部首席技术官 徐景辉
汪文君是我们软件开发团队里特别有朝气的一员,平时不管是工作还是业余时间,其都会对软件开发遇到的难题、专题进行不折不挠的攻关研究,他是团队所有人心目中的技术大牛。我作为部门主管,从三个月前得知他开始写这本书时,就特别期待,之前他利用业余时间录制网上视频供大家学习与交流,现在他把这些知识再加以整理出版成书,相信他的所作所为能让许多人受益。
——Head of Data Engineering at HSBC Winne Chen
书摘
---------------------------Java并发编程实战---------------------------
版权页:
插图:
第一章简介
编写正确的程序很难,而编写正确的并发程序則难上加难。与串行程序相比,在并发程序中存在更多容易出错的地方。那么,为什么还要编写并发程序?线程是Java语言中不可或缺的重要功能,它们能使复杂的异步代码变得更简单,从而极大地简化了复杂系统的开发。此外,要想充分发挥多处理器系统的强大计算能力,最简单的方式就是使用线程。随着处理器数量的持续增长,如何高效地使用并发正变得越来越重要。
1.1 并发简史
在早期的计算机中不包含操作系统,它们从头到尾只执行一个程序,并且这个程序能访问计算机中的所有资源。在这种裸机环境中,不仅很难编写和运行程序,而且每次只能运行一个程序,这对于昂贵并且稀有的计算机资源来说也是一种浪费。
操作系统的出现使得计算机每次能运行多个程序,并且不同的程序都在单独的进程中运行:操作系统为各个独立执行的进程分配各种资源,包括内存,文件句柄以及安全证书等。如果需要的话,在不同的进程之间可以通过一些粗粒度的通信机制来交换数据,包括:套接字、信号处理器、共享内存、信号量以及文件等。
之所以在计算机中加入操作系统来实现多个程序的同时执行,主要是基于以下原因:
资源利用率。在某些情况下,程序必须等待某个外部操作执行完成,例如输入操作或输出操作等,而在等待时程序无法执行其他任何工作。因此,如果在等待的同时可以运行另一个程序,那么无疑将提高资源的利用率。
公平性。不同的用户和翠序对于计算机上的资源有着同等的使用权。一种高效的运行方式是通过粗粒度的时间分片(Time Slicing)使这些用户和程序能共享计算机资源,而不是由一个程序从头运行到尾,然后再启动下一个程序。
便利性。通常来说,在计算多个任务时,应该编写多个程序,每个程序执行一个任务并在必要时相互通信,这比只编写一个程序来计算所有任务更容易实现。