以下代码为例:
System.out.println(Arrays.toString("中".getBytes("UTF-8")));
输出结果:
[-28, -72, -83]
Unicode编码是指定一个值对应一个字符
所以:0x4e2d --> 中,所以底层存储还是2个字节,只是在getBytes方法在得到时,底层进行了转换
将底层数据转换为UTF-8格式的规则:
0x4e2d 范围在0x800 ~ 0xFFFF之间
0x4e2d二进制为:0100 1110 0010 1101
则UTF-8编码方式转换: 变为了三个字节,如下图
11100100 10111000 10101101
三字节转为byte依次为
11100100 -> 有符号,减1 -> 11100011,取反 -> 00011100 -> 转10进制,4+8+16=28 -> -28
10111000 -> -72
10101101 -> -83