java String.getBytes输出是怎么算出来的

以下代码为例:

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

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值