我正在尝试创建一个Hashtable,如下所示:
Hashtable<int,ArrayList<byte>> block = new Hashtable<int,ArrayList<byte>>();
但是我在整数和字节上都会显示“这个令牌后面的尺寸”.
如果我使用像:
哈希表< String,byte []> – 一切都很好.有人可以解释为什么吗
谢谢.
解决方法
在Java的核心集合类中,您只能存储引用类型(扩展java.lang.Object的东西).您不能存储像int和byte这样的原语.请注意,像byte []的数组不是原始的,也是一个引用类型.
正如@Giuseppe所说,你可以这样定义它:
Hashtable<Integer,ArrayList<Byte>> table = new Hashtable<Integer,ArrayList<Byte>>();
然后把原始的int放在它中作为键:
table.put(4,...);
因为自从Java 1.5以来,autoboxing将自动将原始int改成后面的整数(包装).
如果您需要更多的速度(并且测量包装收集类是问题!),您可以使用第三方库,可以在其集合中存储原语.这种图书馆的一个例子是Trove和Colt.