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

JVM执行一个称为锁定精灵的整洁技巧,以避免锁定只能在一个线程上可见的对象的成本.

这里有一个很好的描述:

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

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

解决方法

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

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

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

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

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...