之前讲了一些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
暂无评论内容