java – CLR执行“锁定精灵”优化?如果不是为什么不呢?

前端之家收集整理的这篇文章主要介绍了java – CLR执行“锁定精灵”优化?如果不是为什么不呢?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
JVM执行一个称为锁定精灵的整洁技巧,以避免锁定只能在一个线程上可见的对象的成本.

这里有一个很好的描述:

http://www.ibm.com/developerworks/java/library/j-jtp10185/

.Net CLR是否做类似的事情?如果不是,那为什么不呢?

解决方法

很整洁,但有用吗?我很难想出一个示例,编译器可以证明锁是线程本地的.几乎所有的类都不使用锁定默认情况下,当你选择一个锁定,那么在大多数情况下,它会引用一些静态变量来代替编译器优化.

另一件事是,java vm在其证明中使用逃逸分析.而AFAIK .net尚未实施逃逸分析.逃逸分析的其他用途,例如用堆栈分配替换堆分配,听起来更有用,应该首先实现.

IMO目前不值得编码工作. .net VM中有很多方面没有优化,影响更大.

SSE向量指令和委托内联是两个示例,我的代码可以从这个优化中获益匪浅.

猜你在找的Java相关文章