嘿,我正在试图找出[B @前缀在java中的含义。当我尝试打印字节数组时它们会出来。但是,大小为32和大小为4的字节数组的长度相同。始终“[@ B1234567”。
这是什么?此外,它们具有仅打印十六进制值的属性。我知道它不能只是二进制打印,因为会出现随机扩展的ascii字符。这是一个byte []到byte []哈希表映射打印的示例,其中映射由冒号分隔,这些是4字节键和32字节元素的字节数组。
[B@1ef9157:[B@1f82982
[B@181ed9e:[B@16d2633
[B@27e353:[B@e70e30
[B@cb6009:[B@154864a
[B@18aaa1e:[B@3c9217
[B@20be79:[B@9b42e6
[B@16925b0:[B@14520eb
[B@8ee016:[B@1742700
[B@1bfc93a:[B@acb158
[B@107ebe1:[B@1af33d6
[B@156b6b9:[B@17431b9
[B@139b78e:[B@16c79d7
[B@2e7820:[B@b33d0a
[B@82701e:[B@16c9867
[B@1f14ceb:[B@89cc5e
[B@da4b71:[B@c837cd
[B@ab853b:[B@c79809
[B@765a16:[B@1ce784b
[B@1319c:[B@3bc473
答案 0 :(得分:40)
您正在查看对象ID,而不是内容的转储。
如果打算打印数组的内容,有很多方法。例如:
byte[] in = new byte[] { 1, 2, 3, -1, -2, -3 };
System.out.println(byteArrayToString(in));
String byteArrayToString(byte[] in) {
char out[] = new char[in.length * 2];
for (int i = 0; i < in.length; i++) {
out[i * 2] = "0123456789ABCDEF".charAt((in[i] >> 4) & 15);
out[i * 2 + 1] = "0123456789ABCDEF".charAt(in[i] & 15);
}
return new String(out);
}
可以在complete list中找到JNI documentation类型命名法。
以下是整个清单:
L
和;
之间是完整的班级名称,使用/
作为包之间的分隔符(例如,Ljava/lang/String;
)[
(I)V
,附加伪类型V
无效方法答案 1 :(得分:4)
[B @表示“字节数组”。其他原始数组类型具有不同的前缀:
class Test
{
public static void main(String [] args)
{
byte[] b = new byte[0];
int[] i = new int[0];
char[] c = new char[0];
long[] l = new long[0];
double[] d = new double[0];
float[] f = new float[0];
short[] s = new short[0];
System.out.println(b);
System.out.println(i);
System.out.println(c.toString());
System.out.println(l);
System.out.println(d);
System.out.println(f);
System.out.println(s);
}
}
打印:
[B@3e25a5
[I@19821f
[C@addbf1
[J@42e816
[D@9304b1
[F@190d11
[S@a90653
非基本类型包括[L
之后的类型名称:
[Ljava.lang.String;@a90653
[Ljava.lang.Object;@de6ced
如果要将字节数组的内容打印为十六进制,可以使用以下代码来帮助您:
class Test
{
public static void main(String [] args)
{
byte[] b = new byte[] { (byte) 0xf3, (byte) 0xf1, (byte) 0x7f };
System.out.println(toHex(b));
}
private static final char[] HEX_DIGITS = "0123456789abcdef".toCharArray();
public static String toHex(byte[] bytes)
{
char[] c = new char[bytes.length*2];
int index = 0;
for (byte b : bytes)
{
c[index++] = HEX_DIGITS[(b >> 4) & 0xf];
c[index++] = HEX_DIGITS[b & 0xf];
}
return new String(c);
}
}
答案 2 :(得分:2)
默认toString()
实现是类名,后跟'@',后跟对象的哈希码(十六进制)。
反过来,默认的哈希码“通常通过将对象的内部地址转换为整数来实现”。实际上,Sun JVM使用对象句柄的地址作为输入来生成默认的哈希码。
对于基本类型(int
,char
等)或数组类型(如byte[]
),使用Java Virtual Machine Specification中为字段描述符定义的命名规则。根据这些规则,一个'['表示一个维度的数组,而'B'表示组件类型byte
。
答案 3 :(得分:1)
我怀疑,虽然我不知道,十六进制字符串是内存中实例地址的表示,并且可能与数组的长度没什么关系。你能澄清一下你的问题吗?
答案 4 :(得分:0)
值得注意的是,equals()来自Object,所以如果a.equals(b)则a == b。即如果你有两个包含相同数据的字节数组,它们不是equals(),并且不匹配Hashtable,HashXxxx中的键
答案 5 :(得分:-1)
当我使用csv输入组件时遇到了这个问题。几个小时后,我发现这些值是字节。我解决了此问题,在“选择值”组件上为参数Binary to normal选择了“是”。