synchronized在java中的原理分析

之前讲了一些synchronized的用法,那么对于这些使用的产生,我们要从synchronized的原理中去寻找。就synchronized的使用而言,分为底层原理、同步原理和可重入原理。我们需要在其中分析出synchronized一些锁作用的机制,这里以JVM为切入点,为大家展开其原理的解析。

1.底层原理

对于原理,最好的方式就是深入到JVM中去。我们可以编译看看其字节码文件,再来分析,因此在这里举一个最简单的例子。

publicclassSynTest11{
privateObjectobject=newObject();
publicvoidtest(){
synchronized(object){
System.out.println("java的架构师技术栈");
}
}

}

2.同步原理

数据同步需要依赖锁,那锁的同步又依赖谁?synchronized给出的答案是在软件层面依赖JVM,而j.u.c.Lock给出的答案是在硬件层面依赖特殊的CPU指令。

当一个线程访问同步代码块时,首先是需要得到锁才能执行同步代码,当退出或者抛出异常时必须要释放锁,那么它是如何来实现这个机制的呢?我们先看一段简单的代码:

packagecom.paddx.test.concurrent;
publicclassSynchronizedDemo{
publicvoidmethod(){
synchronized(this){
System.out.println("Method1start");
}
}
}

3.可重入原理

在之前曾提到可重入的性质,那么synchronized关键字是如何保证的呢?其是工作是由我们的jvm来完成的,线程第一次给对象加锁的时候,计数为1,以后这个线程再次获取锁的时候,计数会依次增加。同理,任务离开的时候,相应的计数器也会减少。

原文来自:https://www.py.cn

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容