与Java并发编程相关的概念和注意事项有哪些?很多新手对此不是很清楚。为了帮助大家解决这个问题,下面小编就为大家详细讲解一下。有这种需求的人可以学习,希望你能有所收获。
相应的概念在Java中的具体表现形式,及使用中应注意的几个问题?
在Java并发编程中,synchronized这个词在早期会被广泛使用,除非开发人员熟悉J.U.C包中的相关工具类来替代它们。
这里的Synchronized也叫隐式锁、内置锁或托管锁,它们都指的是同一个锁,所以当你看到一个新概念时,你不应该感到惊讶。这里的锁似乎是看不见的。我们开发者只是通过关键词来使用,并不关心锁的获取和释放等细节。
本质上,隐式锁定是通过在JVM的指令层添加与监控进入和退出相关的指令来实现的。
例如,下面几行代码:
对象o=新对象();
public void test(){ 0
synchronized(o)
system . out . println(o);
}
}
转换后的jvm指令如下,注意监视器指令。
与同步锁相比,J.U.C中的再入锁和读写锁需要开发人员获取和释放显式锁,其实现形式各不相同。根据使用场景,如果需要更细粒度的控制锁,可以使用J.U.C的实现。
在Java并发编程中,另一个经常使用且容易被误用的是volatile。
一般我们用volatile来设置和判断一些重要的标记,比如这个。
publicationstativatileboondoff=false;在这种情况下,当其他线程修改标识符时,可以保证稍后执行的线程的可见性。
对于这种类型的声明,只有volatile是不够的:
publicationstativatileintcount=0;如果在这里,我们使用count作为计数器,并对每个线程的请求进行计数。在这种情况下,除非我们显式添加锁,否则结果不会达到预期。
这是因为整个计数不是一个整体,尽管它在形式上似乎是不可分割的。但它实际上是由取值、加1和赋值的步骤组成的。多线程执行时,容易造成混乱,最终结果不符合预期。
使用volatile无法实现安全计数。毕竟是抑制CPU进行指令重排序,可以实时获取最新成果进行写作和阅读,不受JMM影响。为了实现安全的计数或递增,需要锁干预,以保证整个计数操作互斥。在整个关键区域,一个线程的计数操作不受其他线程的影响。
另外,在Java并发编程中,用synchronized锁定时,需要注意的一个问题是:
你只能在拥有锁后等待并通知它。
否则,您将会遇到此异常:
线程“main”中出现异常。IllegalMonitorStateException
这就像一个人喊着要把他的面包给你,但他只有空气…你往他脸上吐口水,:).
阅读以上内容对你有帮助吗?如果您想了解更多相关知识或阅读更多相关文章,请关注行业资讯频道,感谢您的支持。
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/44632.html