文档章节

身为JAVA工作者必须了解的实战知识(九)

 叶荷
发布于 2017/08/29 19:23
字数 1234
阅读 31
收藏 0

钉钉、微博极速扩容黑科技,点击观看阿里云弹性计算年度发布会!>>>

一、死锁

所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。百科百科

当两个以上的运算单元,双方都在等待对方停止运行,以取得系统资源,但是没有一方提前退出时,这种状况,就称为死锁。维基百科

1. 顺序死锁

最少有两个锁,一个线程获取到A锁需要获取B锁才能进行操作,而另外一个线程获取到了B锁,需要获取A锁才能执行操作,这种情况下容易出现顺序死锁。

[java]view plaincopy

print?

publicclassLeftRightDeadlock {

privatefinalObject left =newObject();

privatefinalObject right =newObject();

publicvoidleftRight() {

synchronized(left) {

synchronized(right) {

// doSomething();

}

}

}

publicvoidrightLeft() {

synchronized(right) {

synchronized(left) {

// doSomething();

}

}

}

}

2. 动态的锁顺序死锁

[java]view plaincopy

print?

publicvoidtransferMoney(Account fromAccount, Account toAccount, DollarAmount anount)

throwsInsufficientResourcesException {

synchronized(fromAccount) {

synchronized(toAccount) {

if(fromAccount.getBalance().compareTo(amount) <0) {

thrownewInsufficientResourcesException();

}else{

fromAccount.debit(anount);

toAccount.credit(anount);

}

}

}

}

A: transferMoney(myAccount, yourAccount, 10);

B: transferMoney(yourAccount, myAccount, 20);

由外部传入的变量所有锁的条件,但是由以上传入的变量可以看到,这种情况下会出现一个线程先获取myAccount锁在申请yourAccount锁,而另外一个线程相反先获取yourAccount锁在申请myAccount锁。

[java]view plaincopy

print?

privatestaticfinalObject tieLock =newObject();

publicvoidtransferMoney(finalAccount fromAccount,finalAccount toAccount,finalDollarAmount anount)

throwsInsufficientResourcesException {

classHelper{

publicvoidtransfer()throwsInsufficientResourcesException {

if(fromAccount.getBalance().compareTo(amount) <0){

thrownewInsufficientResourcesException();

}else{

fromAccount.debit(anount);

toAccount.credit(anount);

}

}

}

intfromHash = System.identityHashCode(fromAccount);

inttoHash = System.identityHashCode(toAccount);

if(fromHash < toHash){

synchronized(fromAccount){

synchronized(toAccount) {

newHelper().transfer();

}

}

}elseif(fromHash >  toHash){

synchronized(toAccount){

synchronized(fromAccount) {

newHelper().transfer();

}

}

}else{

synchronized(tieLock) {

synchronized(fromAccount) {

synchronized(toAccount) {

newHelper().transfer();

}

}

}

}

}

3. 在协作对象之间发生的死锁

[java]view plaincopy

print?

classTaxi {

privatePoint location, destination;

privatefinalDispatcher dispatcher;

publicTaxi(Dispatcher dispatcher) {

this.dispatcher = dispatcher;

}

publicsynchronizedPoint getLocation(){

returnlocation;

}

publicsynchronizedvoidsetLocation(Point location){

this.location = location;

if(location.equals(destination)){

dispatcher.notifyAvaliable(this);

}

}

}

classDispatcher {

privatefinalSet taxis;

privatefinalSet avaliableTaxis;

publicDispatcher(){

taxis =newHashSet();

avaliableTaxis =newHashSet();

}

publicsynchronizedvoidnotifyAvaliable(Taxi taxi) {

avaliableTaxis.add(taxi);

}

publicsynchronizedImage getImage(){

Image image =newImage();

for(Taxi t :taxis){

image.drawMarker(t.getLocation());

}

returnimage;

}

}

4. 开放调用

-- 待填充

5. 资源死锁

外部锁常被忽视而导致死锁,例如数据库的锁

二、死锁的避免与诊断

1. 支持定时的死锁

存在一些预防死锁的手段,比如Lock的tryLock,JDK 7中引入的Phaser等。

2. 通过线程转储信息来分析死锁

通过Dump线程的StackTrace,例如linux下执行命令 kill -3 ,或者jstack –l ,或者使用Jconsole连接上去查看线程的StackTrace,由此来诊断死锁问题。

三、其他活跃性危险

1. 饥饿

2. 糟糕的响应性

3. 活锁

四、锁的使用

使用支持CAS的数据结构,避免使用锁,如:AtomicXXX、ConcurrentMap、CopyOnWriteList、ConcurrentLinkedQueue

死锁经常是无法完全避免的,鸵鸟策略被很多基础框架所采用。

存在检测死锁的办法

以上就是我推荐给Java开发者们的一面试经典知识。但是这些知识里面并没有太多Java全栈、Java晋阶、JAVA架构之类的题,不是我不推荐,而是希望大家更多的从基本功做起,打好基础,太多复杂的内容一会儿也说不明白。

好了同学们,我能介绍的也都全部介绍完给你们了,如果下获得更多JAVA教学资源,可以选择来我们这里共同交流,群:24044837,很多大神在这里切磋学习,不懂可以直接问,晚上还有大牛免费直播教学。

注:加群要求

1、具有一定工作经验的,面对目前流行的技术不知从何下手,需要突破技术瓶颈的可以加,有些应届生和实习生也可以加。

2、在公司待久了,过得很安逸,但跳槽时面试碰壁。需要在短时间内进修、跳槽拿高薪的可以加。

3、如果没有工作经验,但基础非常扎实,对java工作机制,常用设计思想,常用java开发框架掌握熟练的,可以加。

4、觉得自己很牛B,一般需求都能搞定。但是所学的知识点没有系统化,很难在技术领域继续突破的可以加。

5.阿里Java高级大牛直播讲解知识点,分享知识,多年工作经验的梳理和总结,带着大家全面、科学地建立自己的技术体系和技术认知!

PS:现在主要讲解的内容是(反射原理枚举原理与应用注解原理常用设计模式、正规表达式高级应用、JAVA操作Office原理详解JAVA图像处理技术,等多个知识点的详解和实战)

6.小号或者小白之类加群一律不给过,谢谢。

最后,每一位读到这里的网友,感谢你们能耐心地看完。觉得对你有帮助可以给个喜欢!希望在成为一名更优秀的Java程序员的道路上,我们可以一起学习、一起进步

粉丝 0
博文 24
码字总数 41519
作品 0
私信 提问
加载中
请先登录后再评论。
学习自动化测试须知

转载自本人公众号:自动化测试 在我写关于自动化测试的文章之前,以及读者在决定学习自动化测试之前,需要了解以下内容,并真正做好学习自动化测试的准备。 什么是自动化测试? 自动化测试是...

AllenLife
2018/05/29
0
0
Java程序员必读的经典书籍

身为Java程序员的你可能正在思考平时应该看一些什么书籍来提高自己的能力,那么今天我就给大家推荐一些我曾经看过的经典书籍。 1.《Java从入门到精通(第3版)》 这本书从Java初学者角度出发...

濡沫
2018/08/10
38
0
fbf的书单,欢迎分享,欢迎更新

本人看过的以下书值得推荐的,列出来的就是值得推荐的 这个颜色是一般推荐 这个颜色是强烈推荐 这个颜色是神作,收藏吧 物联网:生产力的变革 李虹著 开拓视野,一般 源码中国:全球IT外包新原...

fbf
2015/03/16
190
0
【有奖书评】JAVA 7来袭,还看 Java 你就OUT了

从1995年至今,Java已经超过15个年头,经过这些年的演进,Java已不仅是个程序语言,也代表了解决问题的平台(Platform),更代表了原厂、各个厂商、社群、开发者与用户沟通的成果。若仅以程序语...

louise
2012/08/31
1.3W
121
京东资深架构带你深入理解JVM高级特性+最佳实践

【推荐】2020年最新Java电子书集合.pdf(吐血整理) >>> 前言 Java是目前用户最多、使用范围最广的软件开发技术之一。Java 的技术体系主要由支撑Java程序运行的虚拟机、提供各开发领域接口支持...

白楠楠
03/06
17
0

没有更多内容

加载失败,请刷新页面

加载更多

18行Python代码抢京东神券

点击上方『早起Python』关注 回复送书参与赠书活动! 一、背景介绍 我们经常能看到京东上有满200减100之类的大额神券,但是当自己激动的等在电脑旁,手拿鼠标、眼盯屏幕,等着倒计时慢慢临近...

早起Python
05/31
0
0
关于SMP

欢迎关注公众号 VxWorks567。如转载,请标出处! 多核在嵌入式实时系统里应用的越来越多,而VxWorks从6.6开始支持多核,到6.8就算支持的不错了。风河提供了两种多核技术:Symmetric multipr...

taishan3721
2019/10/27
0
0
Unity安卓共享纹理

前置知识:安卓集成Unity开发示例 本文的目的是实现以下的流程: Android/iOS native app 操作摄像头 -> 获取视频流数据 -> 人脸检测或美颜 -> 传输给 Unity 渲染 -> Unity做出更多的效果(滤...

osc_4b2ephd0
17分钟前
7
0
计算机网络中这些高频考题,你还在死记硬背吗?(一)

原文链接:原文来自个人公众号—C you again 对于IT从业者来说,计算机网络是一门必修课,也是一块硬骨头,不论是你是在工作中还是面试时,都需要掌握一些网络技术。从本期开始,小编对计算机...

osc_sb30h1xb
19分钟前
4
0
30岁+程序员职场攻略:找到自己的“职业锚”乘风破浪

摘要:何时都不算晚,只要你愿意开始!年龄,不应该是限制你未来可能性的理由。不要给自己贴标签,像姐姐们一样在事业场、生活场上乘风破浪! 都说三个女人一台戏,那30个年龄30+的女明星,聚...

华为云开发者社区
20分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部