jvm
awesome_go
这个作者很懒,什么都没留下…
展开
-
volatile 伪共享问题
伪共享 false sharing,顾名思义,“伪共享”就是“其实不是共享”。那什么是“共享”?多CPU同时访问同一块内存区域就是“共享”,就会产生冲突,需要控制协议来协调访问。会引起“共享”的最小内存区域大小就是一个cache line。因此,当两个以上CPU都要访问同一个cache line大小的内存区域时,就会引起冲突,这种情况就叫“共享”。但是,这种情况里面又包含了“其实不是共享”的“伪共享”情况。比如,两个处理器各要访问一个word,这两个word却存在于同一个cache line大小的区域里,.原创 2020-08-20 09:43:45 · 911 阅读 · 0 评论 -
synchronized 的原理
synchronized修饰方法更加准确的说法应该是修饰实例方法,而不包括静态方法。关键字synchronized取得的锁都是对象锁,而不是把一段代码或方法当作锁。原因在于,要调用一个实例方法必须要new一个对应的实例对象,通过此实例对象才能访问实例方法。要实现同步,那么不同线程的锁必须是访问的同一个对象。这也是从设计角度来讲,为何notify, wait等和锁相关的方法定义在Object这个类中,而非Thread类中的原因之一。如果多个线程访问多个对象,则JVM会创建多个锁。牢记:只有共享资.原创 2020-08-15 17:03:46 · 214 阅读 · 0 评论 -
java8 Stream 使用教程
为什么需要 StreamStream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念。它也不同于 StAX 对 XML 解析的 Stream,也不是 Amazon Kinesis 对大数据实时处理的 Stream。Java 8 中的 Stream 是对集合(Collection)对象功能的增强,它专注于对集合对象进行各种非常便利、高效的聚合操作(aggregate operation),或者大批量数据操作 (bulk原创 2020-06-12 14:21:55 · 1383 阅读 · 0 评论 -
JVM故障分析及性能优化系列之七:使用MAT的Histogram和Dominator Tree定位溢出源
JVM故障分析及性能优化系列文章JVM故障分析及性能优化系列之一:使用jstack定位线程堆栈信息JVM故障分析及性能优化系列之二:jstack生成的Thread Dump日志结构解析JVM故障分析及性能优化系列之三:jstat命令的使用及VM Thread分析JVM故障分析及性能优化系列之四:jstack生成的Thread Dump日志线程状态JVM故障分析及性能优化系列之五:常见的Thre...原创 2020-02-28 14:10:25 · 330 阅读 · 0 评论