您的位置:首页 > 产品设计 > UI/UE

identityHashCode, WeakReference,ReferenceQueue和Lucene WeakIdentityMap

2016-04-18 14:16 447 查看
identityHashCode:

具有不变性,对象产生后identityHashCode不变,通过保存在对象头的mark word中实现,一般占25字节,故一个对象产生之后identityHashCode总是不变:
http://stackoverflow.com/questions/1063068/how-does-the-jvm-ensure-that-system-identityhashcode-will-never-change
不保证唯一,但足够随机(Marsaglia xorshift算法):
http://erikengbrecht.blogspot.com/2008/07/systemidentityhashcode.html
计算System.identityHashCode时要锁住,避免两个对象产生相同的identityHashCode,这就是为什么通常看到lucene会卡在这里.

可以让identityHashCode回绕时抛出异常,让JVM直接crash。

WeakReference和ReferenceQueue:

区别于强引用,引用的对象可以被回收,回收后ref.get() == null。其构造函数为(Object, ReferenceQueue),Reference Queue的作用是拿到对应的失效引用。弱引用一般用来做缓存。

WeakIdentityMap就出来了,它是弱引用对象的map,因为identityHashCode不保证唯一,所以它不是绝对安全的。

ByteBufferIndexInput用到了WeakIdentityMap,因为ByteBufferIndexInput.buildSlice之后产生了对原来的ByteBuffer的引用,需要在close时去掉对其buffers的引用
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: