自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(1)
  • 资源 (129)
  • 收藏
  • 关注

转载 高效程序员的45个习惯

记下高效程序员的45个习惯,共勉吧。 态度篇 1. 做实事 不要抱怨,发牢骚,指责他人,找出问题所在,想办法解决。对问题和错误,要勇于承担。 2. 欲速则不达 用小聪明、权宜之计解决问题,求快而不顾代码质量,会给项目留下要命的死角。 3. 对事不对人 就事论事,明智、真诚、虚心地讨论问题,提出创新方案。 4. 排除万难,奋勇前进 勇气往往是克服

2012-10-05 21:12:13 381

java并发编程实战pdf及源码

目录 对本书的赞誉 译者序 前 言 第1章 简介  1.1 并发简史  1.2 线程的优势   1.2.1 发挥多处理器的强大能力   1.2.2 建模的简单性   1.2.3 异步事件的简化处理   1.2.4 响应更灵敏的用户界面  1.3 线程带来的风险   1.3.1 安全性问题   1.3.2 活跃性问题   1.3.3 性能问题  1.4 线程无处不在 第一部分 基础知识  第2章 线程安全性   2.1 什么是线程安全性   2.2 原子性    2.2.1 竞态条件    2.2.2 示例:延迟初始化中的竞态条件    2.2.3 复合操作   2.3 加锁机制    2.3.1 内置锁    2.3.2 重入   2.4 用锁来保护状态   2.5 活跃性与性能  第3章 对象的共享   3.1 可见性    3.1.1 失效数据    3.1.2 非原子的64位操作    3.1.3 加锁与可见性    3.1.4 Volatile变量   3.2 发布与逸出   3.3 线程封闭    3.3.1 Ad-hoc线程封闭    3.3.2 栈封闭    3.3.3 ThreadLocal类   3.4 不变性    3.4.1 Final域    3.4.2 示例:使用Volatile类型来发布不可变对象   3.5 安全发布    3.5.1 不正确的发布:正确的对象被破坏    3.5.2  不可变对象与初始化安全性    3.5.3 安全发布的常用模式    3.5.4 事实不可变对象    3.5.5 可变对象    3.5.6 安全地共享对象  第4章 对象的组合   4.1 设计线程安全的类    4.1.1 收集同步需求    4.1.2 依赖状态的操作    4.1.3 状态的所有权   4.2 实例封闭    4.2.1 Java监视器模式    4.2.2 示例:车辆追踪   4.3 线程安全性的委托    4.3.1 示例:基于委托的车辆追踪器    4.3.2 独立的状态变量    4.3.3 当委托失效时    4.3.4 发布底层的状态变量    4.3.5 示例:发布状态的车辆追踪器   4.4 在现有的线程安全类中添加功能    4.4.1 客户端加锁机制    4.4.2 组合   4.5 将同步策略文档化  第5章 基础构建模块   5.1 同步容器类    5.1.1 同步容器类的问题    5.1.2 迭代器与Concurrent-ModificationException    5.1.3 隐藏迭代器   5.2 并发容器    5.2.1 ConcurrentHashMap    5.2.2 额外的原子Map操作    5.2.3 CopyOnWriteArrayList   5.3 阻塞队列和生产者-消费者模式    5.3.1 示例:桌面搜索    5.3.2 串行线程封闭    5.3.3 双端队列与工作密取   5.4 阻塞方法与中断方法   5.5 同步工具类    5.5.1 闭锁    5.5.2 FutureTask    5.5.3 信号量    5.5.4 栅栏   5.6 构建高效且可伸缩的结果缓存 第二部分 结构化并发应用程序  第6章 任务执行   6.1 在线程中执行任务    6.1.1 串行地执行任务    6.1.2 显式地为任务创建线程    6.1.3 无限制创建线程的不足   6.2 Executor框架    6.2.1 示例:基于Executor的Web服务器    6.2.2 执行策略    6.2.3 线程池    6.2.4 Executor的生命周期    6.2.5 延迟任务与周期任务   6.3 找出可利用的并行性    6.3.1 示例:串行的页面渲染器    6.3.2 携带结果的任务Callable与Future    6.3.3 示例:使用Future实现页面渲染器    6.3.4 在异构任务并行化中存在的局限    6.3.5 CompletionService:Executor与BlockingQueue    6.3.6 示例:使用CompletionService实现页面渲染器    6.3.7 为任务设置时限    6.3.8 示例:旅行预定门户网站  第7章 取消与关闭   7.1 任务取消    7.1.1 中断    7.1.2 中断策略    7.1.3 响应中断    7.1.4 示例:计时运行    7.1.5 通过Future来实现取消    7.1.6 处理不可中断的阻塞    7.1.7 采用newTaskFor来封装非标准的取消   7.2 停止基于线程的服务    7.2.1 示例:日志服务    7.2.2 关闭ExecutorService    7.2.3 “毒丸”对象    7.2.4 示例:只执行一次的服务    7.2.5 shutdownNow的局限性   7.3 处理非正常的线程终止   7.4 JVM关闭    7.4.1 关闭钩子    7.4.2 守护线程    7.4.3 终结器  第8章 线程池的使用   8.1 在任务与执行策略之间的隐性耦合    8.1.1 线程饥饿死锁    8.1.2 运行时间较长的任务   8.2 设置线程池的大小   8.3 配置ThreadPoolExecutor    8.3.1 线程的创建与销毁    8.3.2 管理队列任务    8.3.3 饱和策略    8.3.4 线程工厂    8.3.5 在调用构造函数后再定制ThreadPoolExecutor   8.4 扩展 ThreadPoolExecutor   8.5 递归算法的并行化  第9章 图形用户界面应用程序   9.1 为什么GUI是单线程的    9.1.1 串行事件处理    9.1.2 Swing中的线程封闭机制   9.2 短时间的GUI任务   9.3 长时间的GUI任务    9.3.1 取消    9.3.2 进度标识和完成标识    9.3.3 SwingWorker   9.4 共享数据模型    9.4.1 线程安全的数据模型    9.4.2 分解数据模型    9.5 其他形式的单线程子系统 第三部分 活跃性、性能与测试  第10章 避免活跃性危险   10.1 死锁    10.1.1 锁顺序死锁    10.1.2 动态的锁顺序死锁    10.1.3 在协作对象之间发生的死锁    10.1.4 开放调用    10.1.5 资源死锁   10.2 死锁的避免与诊断    10.2.1 支持定时的锁    10.2.2 通过线程转储信息来分析死锁   10.3 其他活跃性危险    10.3.1 饥饿    10.3.2 糟糕的响应性    10.3.3 活锁  第11章 性能与可伸缩性   11.1 对性能的思考    11.1.1 性能与可伸缩性    11.1.2 评估各种性能权衡因素   11.2 Amdahl定律    11.2.1 示例:在各种框架中隐藏的串行部分    11.2.2 Amdahl定律的应用   11.3 线程引入的开销    11.3.1 上下文切换    11.3.2 内存同步    11.3.3 阻塞   11.4 减少锁的竞争    11.4.1 缩小锁的范围(“快进快出”)    11.4.2 减小锁的粒度    11.4.3 锁分段    11.4.4 避免热点域    11.4.5 一些替代独占锁的方法    11.4.6 监测CPU的利用率    11.4.7 向对象池说“不”   11.5 示例:比较Map的性能   11.6 减少上下文切换的开销  第12章 并发程序的测试   12.1 正确性测试    12.1.1 基本的单元测试    12.1.2 对阻塞操作的测试    12.1.3 安全性测试    12.1.4 资源管理的测试    12.1.5 使用回调    12.1.6 产生更多的交替操作   12.2 性能测试    12.2.1 在PutTakeTest中增加计时功能    12.2.2 多种算法的比较    12.2.3 响应性衡量   12.3 避免性能测试的陷阱    12.3.1 垃圾回收    12.3.2 动态编译    12.3.3 对代码路径的不真实采样    12.3.4 不真实的竞争程度    12.3.5 无用代码的消除   12.4 其他的测试方法    12.4.1 代码审查    12.4.2 静态分析工具    12.4.3 面向方面的测试技术    12.4.4 分析与监测工具 第四部分 高级主题  第13章 显式锁   13.1 Lock与 ReentrantLock    13.1.1 轮询锁与定时锁    13.1.2 可中断的锁获取操作    13.1.3 非块结构的加锁   13.2 性能考虑因素   13.3 公平性   13.4 在synchronized和ReentrantLock之间进行选择   13.5 读-写锁  第14章 构建自定义的同步工具   14.1 状态依赖性的管理    14.1.1 示例:将前提条件的失败传递给调用者    14.1.2 示例:通过轮询与休眠来实现简单的阻塞    14.1.3 条件队列   14.2 使用条件队列    14.2.1 条件谓词    14.2.2 过早唤醒    14.2.3 丢失的信号    14.2.4 通知    14.2.5 示例:阀门类    14.2.6 子类的安全问题    14.2.7 封装条件队列    14.2.8 入口协议与出口协议   14.3 显式的Condition对象   14.4 Synchronizer剖析   14.5 AbstractQueuedSynchronizer   14.6 java.util.concurrent同步器类中的 AQS    14.6.1 ReentrantLock    14.6.2 Semaphore与CountDownLatch    14.6.3 FutureTask    14.6.4 ReentrantReadWriteLock  第15章 原子变量与非阻塞同步机制   15.1 锁的劣势   15.2 硬件对并发的支持    15.2.1 比较并交换    15.2.2 非阻塞的计数器    15.2.3 JVM对CAS的支持   15.3 原子变量类    15.3.1 原子变量是一种“更好的volatile”    15.3.2 性能比较:锁与原子变量   15.4 非阻塞算法    15.4.1 非阻塞的栈    15.4.2 非阻塞的链表    15.4.3 原子的域更新器    15.4.4 ABA问题  第16章 Java内存模型   16.1 什么是内存模型,为什么需要它    16.1.1 平台的内存模型    16.1.2 重排序    16.1.3 Java内存模型简介    16.1.4 借助同步   16.2 发布    16.2.1 不安全的发布    16.2.2 安全的发布    16.2.3 安全初始化模式    16.2.4 双重检查加锁   16.3 初始化过程中的安全性 附录A 并发性标注 参考文献

2016-03-20

Effective Enterprise Java中文版

序 前言 缩略语 第1章 简介 J2EE的目标 中间件和J2EE J2EE实现 企业计算的十大谬误 第2章 架构 第1项:优先采用构件作为开发、部署和重用的核心元素 第2项:跨越构件边界优先采用松耦合 第3项:区分逻辑层和物理层 第4项:数据和处理程序要尽可能靠近 第5项:牢记标识引起的竞争 第6项:使用“挂钩点”来注入优化、定制或新功能 第7项:面对故障时要健壮 第8项:定义性能和可扩展性目标 第9项:只在事务性处理中使用EJB 第10项:先测量性能,再进行优化 第11项:认清“提供商中立”的成本 第12项:内置监控功能 第13项:内置管理支持 第14项:部署要尽可能简单 第3章 通信 第15项:理解你所做的通信选择 第16项:仔细考虑你的查找 第17项:识别网络访问的代价 第18项:优选上下文完整的通信风格 第19项:优选数据驱动的通信而不是行为驱动的通信 第20项:避免为远程服务请求去等待响应 第21项:考虑构件的划分以避免任何一台机器负载过重 第22项:为了开放集成而考虑使用Web服务 第23项:大批量地传送数据 第24项:考虑定制你自己的通信代理 第4章 处理 第25项:保持简洁 第26项:优先采用规则引擎去处理复杂状态的评估和执行 第27项:优先为隐含的非原子性错误场景采用事务性处理 第28项:区分用户事务和系统事务 第29项:最小化锁窗口 第30项:当持有锁时不要让步给在构件之外的控制 第31项:理解EJB的事务关联 第32项:优先使用本地事务而不是分布式事务 第33项:为了更好的可扩展性而考虑使用乐观的并发机制 第34项:为了显式的并发控制而考虑使用悲观的并发机制 第35项:考虑使用较低的隔离级别以获得更大的事务吞吐量 第36项:面临回滚时使用保存点来保留部分工作 第37项:当有可能避免锁定区域时就复制数据源 第38项:偏爱不可变的,因为它不需要任何锁 第5章 状态管理 第39项:节省地使用 HttpSession 第40项:使用对象优先的持久化来保存你的领域模型 第41项:使用关系优先的持久化来显示关系模型的威力 第42项:使用过程优先的持久化来创建一个封装层 第43项:识别对象-层次结构阻抗失配 第44项:使用进程内或本地存储以避开网络 第45项:不要假设拥有数据或数据库 第46项:惰性加载不频繁使用的数据 第47项:积极加载频繁使用的数据 第48项:批处理SQL的工作以避免往返访问 第49项:了解你的JDBC供应商 第50项:调整你的SQL语句 第6章 表示 第51项:考虑富客户端UI技术 第52项:使HTML短小精悍 第53项:表示与处理相分离 第54项:内容与样式相分离 第55项:预生成内容以最小化处理过程 第56项:尽早验证,尽量验证 第7章 安全 第8章 系统 参考资料

2016-03-13

解析极限编程-拥抱变化(原书第2版).pdf

极限编程(xp)是适用于中小型团队在需求不明确或者迅速变化的情况下进行软件开发的轻量级方法学。本书是xp宣言,也是第一本有关xp的图书。   这本书介绍了xp背后的思想——它的根源、哲学、情节等。它将帮助读者选择是否在项目中使用xp时做出明智的决策。本书的另一个目的是帮助那些已经在使用 xp的读者更好地理解它。 对程序员而言,xp做出的承诺是他们每天能够处理真正重要的工作,而不必单独面对令人担忧的状况。他们将能够集中全力来使他们的系统获得成功。他们将做出最适合由他们来做的决策。对于客户和管理人员而言,xp的承诺是他们将从每个编程周期中获得最多的利益。他们将能够在开发的中途更改项目的方向而不用承担太高的成本。   《解析极限编程--拥抱变化(原书第2版)》适合所有软件开发人员、管理人员参考。

2016-03-12

osgi in action

osgi in action

2016-03-07

SecureCRT

SecureCRT

2016-02-25

VisualRoute.2010.v14.0c.原版+破解

VisualRoute.2010.v14.0c.原版+破解

2016-02-21

PDF_Converter

PDF_Converter 免费的pdf转换器,纯绿色免安装版

2016-02-20

linux 删除当前目录下大小为0的文件

shell 删除 大小为0文件 ,不需要参数,直接在需要清除文件的目录下执行即可

2016-02-17

HTTP权威指南

HTTP权威指南

2016-01-19

HTTP- The Definitive Guide

HTTP- The Definitive

2016-01-18

RESTful Web Services Cookbook 中文版 高清 PDF 电子书

RESTful Web Services Cookbook 中文版 高清 PDF 电子书

2016-01-02

jcaptcha组件jar包

<dependency> <groupId>com.octo.captcha</groupId> <artifactId>jcaptcha-integration-simple-servlet</artifactId> <version>2.0-alpha-1</version> </dependency>

2015-12-30

es脚手架工程

es脚手架工程.

2015-12-28

Hadoop实战(第2版)__陆嘉恒著

Hadoop实战(第2版)__陆嘉恒著

2015-12-13

jd-gui-反编译

jd-gui-反编译

2015-09-26

jstl例子程序

jstl-examples

2015-09-26

AngularJS权威教程

AngularJS权威教程是学习AngularJS的公认经典,内容全面,讲解通俗,适合各层次的学习者。作者拥有丰富的AngularJS开发和教学经验,也是一位全栈工程师。全书35章,由浅入深地讲解了AngularJS的基本概念和基本功能,包括模块、作用域、控制器、表达式、指令、路由、依赖注入等,重要的是书中对每一个概念的讲解都配合了恰如其分的示例和代码,让读者通过动手实践,切身体会到这些概念的含义和价值。《AngularJS权威教程》后半部分深入到AngularJS应用开发,系统地讨论了服务器通信、事件、架构、动画、本地化、安全、缓存、移动应用等主题。

2015-07-08

架构师2015-05

架构师2015-05

2015-06-07

pim_codeStyle.xml

提升java代码的可读行,规范行。该模板严格按照代码的缩进原则进行编写。 使用方法:1 在eclipse中选中一个工程,右键单击->propertys->java code style->formatter->import->导入该xml文件

2015-04-25

maven-db-plugin-1.4

maven-db-plugin-1.4

2015-04-05

Everything文件搜索工具32+64

Everything文件搜索工具32+64

2022-05-05

microservices-in-action.zip

microservices-in-action.zip

2021-04-30

RocketMQ架构原理剖析.7z

RocketMQ架构原理剖析

2019-06-09

JProfiler11_x64_jb51安装与解密.7z

JProfiler11_x64_jb51安装与解密.7z

2019-05-23

Alibaba Java Coding Guidelines

Alibaba Java Coding GuidelinesAlibaba Java Coding GuidelinesAlibaba Java Coding GuidelinesAlibaba Java Coding Guidelines

2018-05-25

mahout测试数据

mahout测试数据 mahout测试数据 mahout测试数据 mahout测试数据 mahout测试数据 mahout测试数据

2018-04-01

《亿级流量网站架构核心技术》PDF下载 高清完整版

《亿级流量网站架构核心技术》PDF下载 高清完整版《亿级流量网站架构核心技术》PDF下载 高清完整版《亿级流量网站架构核心技术》PDF下载 高清完整版《亿级流量网站架构核心技术》PDF下载 高清完整版《亿级流量网站架构核心技术》PDF下载 高清完整版

2017-12-06

Java 8函数式编程_高清版pdf

Java 8函数式编程_高清版pdfJava 8函数式编程_高清版pdfJava 8函数式编程_高清版pdfJava 8函数式编程_高清版pdfJava 8函数式编程_高清版pdfJava 8函数式编程_高清版pdf

2017-12-05

Java NIO (中文版).pdf

Java NIO (中文版).pdfJava NIO (中文版).pdfJava NIO (中文版).pdfJava NIO (中文版).pdfJava NIO (中文版).pdf

2017-10-08

hadoop-core-1.2.1-source.jar

hadoop-core-1.2.1-source.jarhadoop-core-1.2.1-source.jarhadoop-core-1.2.1-source.jarhadoop-core-1.2.1-source.jarhadoop-core-1.2.1-source.jar

2017-10-08

hadoop-core-1.2.0-sources.jar

hadoop-core-1.2.0-sources.jarhadoop-core-1.2.0-sources.jarhadoop-core-1.2.0-sources.jarhadoop-core-1.2.0-sources.jar

2017-10-08

java实现httpclient服务端客户端代码例子

java实现http接口服务端、客户端代码例子。使用jar(commons-codec-1.3.jar、commons-httpclient-3.0.1.jar、commons-logging-1.1.1.jar)

2017-04-13

大数据平台及推荐的应用

大数据平台及推荐的应用 大数据平台及推荐的应用 大数据平台及推荐的应用 大数据平台及推荐的应用 大数据平台及推荐的应用

2017-01-31

大数据日知录_架构与算法

内容简介 · · · · · · 大数据是当前最为流行的热点概念之一,其已由技术名词衍生到对很多行业产生颠覆性影响的社会现象,作为最明确的技术发展趋势之一,基于大数据的各种新型产品必将会对每个人的日常生活产生日益重要的影响。 《大数据日知录:架构与算法》从架构与算法角度全面梳理了大数据存储与处理的相关技术。大数据技术具有涉及的知识点异常众多且正处于快速演进发展过程中等特点,其技术点包括底层的硬件体系结构、相关的基础理论、大规模数据存储系统、分布式架构设计、各种不同应用场景下的差异化系统设计思路、机器学习与数据挖掘并行算法以及层出不穷的新架构、新系统等。《大数据日知录:架构与算法》对众多纷繁芜杂的相关技术文献和系统进行了择优汰劣并系统性地对相关知识分门别类地进行整理和介绍,将大数据相关技术分为大数据基础理论、大数据系统体系结构、大数据存储,以及包含批处理、流式计算、交互式数据分析、图数据库、并行机器学习的架构与算法以及增量计算等技术分支在内的大数据处理等几个大的方向。通过这种体系化的知识梳理与讲解,相信对于读者整体和系统地了解、吸收和掌握相关的优秀技术有极大的帮助与促进作用。 《大数据日知录:架构与算法》的读者对象包括对NoSQL 系统及大数据处理感兴趣的所有技术人员,以及有志于投身到大数据处理方向从事架构师、算法工程师、数据科学家等相关职业的在校本科生及研究生。 作者简介 · · · · · · 张俊林是技术书籍《这就是搜索引擎:核心技术详解》(该书荣获全国第十二届输出版优秀图书奖)的作者,目前担任畅捷通智能平台总监。在此之前,张俊林曾经在阿里巴巴搜索技术中心、百度商务搜索部凤巢广告平台以及新浪微博搜索部及数据系统部担任资深技术专家,新浪微博技术委员会成员,负责算法策略方向。他还曾是智能信息聚合网站“玩聚网”的联合创始人之一。他的研发兴趣集中在:搜索技术、推荐系统、社交挖掘、自然语言处理与大数据算法架构等方面,并在以上领域有多年工业界实践经验。 张俊林本科毕业于天津大学管理学院,1999年至2004年在中科院软件所直接攻读博士学位,研究方向是信息检索理论与自然语言处理,就学期间曾在ACL/COLING/IJCNLP等国际顶级会议发表多篇学术论文,另外,他在此期间领导设计的搜索系统曾在美国国防部DARPA主持的TREC第二届高精度检索系统评测中在17支国际高水平研究团队激烈竞争中胜出,并取得综合排名第一名的优异成绩

2016-11-07

大数据日知录__架构与算法

大数据日知录__架构与算法大数据日知录__架构与算法大数据日知录__架构与算法大数据日知录__架构与算法大数据日知录__架构与算法大数据日知录__架构与算法

2016-11-06

protoc-2.5.0

protoc-2.5.0protoc-2.5.0protoc-2.5.0protoc-2.5.0protoc-2.5.0protoc-2.5.0protoc-2.5.0protoc-2.5.0

2016-06-26

DbVisualizer 9.1.1破解版32位

DbVisualizer 9.1.1破解版32位

2016-06-21

Spark快速数据处理完整版

Spark快速数据处理完整版

2016-05-26

Spark大数据处理:技术、应用与性能优化(全)

Spark大数据处理:技术、应用与性能优化(全)Spark大数据处理:技术、应用与性能优化(全)Spark大数据处理:技术、应用与性能优化(全)Spark大数据处理:技术、应用与性能优化(全)Spark大数据处理:技术、应用与性能优化(全)

2016-04-17

从PAXOS到ZOOKEEPER分布式一致性原理与实践

从PAXOS到ZOOKEEPER分布式一致性原理与实践从PAXOS到ZOOKEEPER分布式一致性原理与实践从PAXOS到ZOOKEEPER分布式一致性原理与实践

2016-03-20

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除