我创建了一个向量集,以避免使用迭代器分配等来破坏GC(对于HashSet的值或键的每次遍历,您为set引用和set迭代器获取new/free)
无论如何,该Object.hashCode()方法应该是每个对象的唯一ID.(对于64位版本会失败吗?)
但无论如何它都是可覆盖的,因此不能保证每个对象实例的唯一性和唯一性.
如果我想创建一个"ObjectSet",我如何获得一个对象的每个实例的保证唯一ID?
我刚刚发现了这个:它回答了它.
Pet*_*rey 39
最简单的解决方案是向对象添加字段.这是最快速,最有效的解决方案,可避免任何对象无法清除的问题.
abstract Ided {
static final AtomicLong NEXT_ID = new AtomicLong(0);
final long id = NEXT_ID.getAndIncrement();
public long getId() {
return id;
}
}
Run Code Online (Sandbox Code Playgroud)
如果您无法修改类,则可以使用IdentityHashMap,例如@ glowcoder的已删除解决方案.
private static final Map<Object, Long> registry = new IdentityHashMap<Object, Long>();
private static long nextId = 0;
public static long idFor(Object o) {
Long l = registry.get(o);
if (l == null)
registry.put(o, l = nextId++);
return l;
}
public static void remove(Object o) {
registry.remove(o);
}
Run Code Online (Sandbox Code Playgroud)
java.lang.System.identityHashCode(obj);如果你真的需要它并了解其影响,我们会为你做这件事.它获取了身份哈希码,即使提供哈希码的方法已被覆盖.