• 欢迎浏览“String me = Creater\忠实的资深Linux玩家;”,请文明浏览,理性发言,有侵犯你的权益请邮件我(creater@vip.qq.com).
  • 把任何的失败都当作一次尝试,不要自卑;把所有的成功都想成是一种幸运,不要自傲。
  •    2年前 (2017-03-08)  C# |   抢沙发  13 
    文章评分 0 次,平均分 0.0

    最近的项目中要使用到把byte[]类型转换成String字符串然后发送,但发现发现出去的字符串和获取的字符串虽然是一样的,但当用String的getBytes()的方法得到的byte[]跟原来的byte[]是不一样的。
    看如下代码:
    bytebytes[] = new byte[] { 50, 0, -1, 28, -24 };
    String string = new String(bytes);
    byte[] ret = string.getBytes();
    查看ret的数据发现是50, 0, -17, -65, -67, 28, -17, -65, -67,发现数据并不是原来的数据。

    而使用如下代码就可以得到原来的数据:

    byte bytes[] = new byte[] { 50, 0, -1, 28, -24 };
    StringisoString = new String(bytes, "ISO-8859-1");
    byte[] isoret = isoString.getBytes("ISO-8859-1");
    

    这是为什么呢? 原因是第一种方法默认是用UTF-8编码来生成String的 ,用System.getProperty("sun.jnu.encoding")可以得到Android默认编码是UTF-8。UTF-8是可变长度的编码,原来的字节数组就被改变了。而ISO8859-1通常叫做Latin-1,Latin-1包括了书写所有西方欧洲语言不可缺少的附加字符,其中 0~127的字符与ASCII码相同,它是单字节的编码方式,这样第二种方式生成的String里的字节数组就跟原来的字节数组一样。在new String使用其他编码如GBK,GB2312的话一样也会导致字节数组发生变化,因此要想获取String里单字节数组,就应该使用iso-8859-1编码。

     

    除特别注明外,本站所有文章均为String me = "Creater\忠实的资深Linux玩家";原创,转载请注明出处来自http://unix8.net/home.php/5406.html

    关于

    发表评论

    暂无评论

    切换注册

    登录

    忘记密码 ?

    切换登录

    注册

    扫一扫二维码分享