JVM执行一个称为锁定精灵的整洁技巧,以避免锁定只能在一个线程上可见的对象的成本.
这里有一个很好的描述:
http://www.ibm.com/developerworks/java/library/j-jtp10185/
.Net CLR是否做类似的事情?如果不是,那为什么不呢?
解决方法
很整洁,但有用吗?我很难想出一个示例,编译器可以证明锁是线程本地的.几乎所有的类都不使用锁定默认情况下,当你选择一个锁定,那么在大多数情况下,它会引用一些静态变量来代替编译器优化.
另一件事是,java vm在其证明中使用逃逸分析.而AFAIK .net尚未实施逃逸分析.逃逸分析的其他用途,例如用堆栈分配替换堆分配,听起来更有用,应该首先实现.
IMO目前不值得编码工作. .net VM中有很多方面没有优化,影响更大.
SSE向量指令和委托内联是两个示例,我的代码可以从这个优化中获益匪浅.