首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

深入理解 Java 并发之 synchronized 实现原理

线程安全是并发编程中的重要关注点,应该注意到的是,造成线程安全问题的主要诱因有两点,一是存在共享数据(也称临界资源),二是存在多条线程共同操作共享数据。因此为了解决这个问题,我们可能需要这样一个方案,当存在多个线程操作共享数据时,需要保证同一时刻有且只有一个线程在操作共享数据,其他线程必须等到该线程处理完数据后再进行,这种方式有个高尚的名称叫互斥锁,即能达到互斥访问目的的锁,也就是说当一个共享数据被当前正在访问的线程加上互斥锁后,在同一个时刻,其他线程只能处于等待的状态,直到当前线程处理完毕释放该锁。在 J

08

《深入理解Java虚拟机》读书笔记(七)–虚拟机字节码执行引擎(上)

用于存放方法参数和方法内定义的局部变量。在编译阶段,就在方法表的Code属性的max_locals数据项确定了方法所需的局部变量表最大空间。其容量以变量槽(slot)为最小单位,虚拟机规范没有明确规定一个slot应占用的空间大小,只是有导向性地说每个slot都应该能存放一个boolean、byte、char、short、int、float、reference或returnAddress类型的数据,这8种数据类型都可以使用32位或更小的内存来存放,但是也允许slot的长度可以随着处理器、操作系统或虚拟机的不同而变化,只要保证即使使用64位的内存空间去实现一个slot,虚拟机仍然要使用对齐和补白的手段让slot在外观上看起来与32位虚拟机中的一致。

04
领券