V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
muzzy
V2EX  ›  Java

Java 字符编码问题

  •  
  •   muzzy · 2018-03-31 14:55:08 +08:00 · 2170 次点击
    这是一个创建于 2190 天前的主题,其中的信息可能已经有所发展或是发生改变。

    String name="思";
    String sendName = new String(name.getBytes("UTF-8"),"GBK");
    System.out.println(sendName);
    String recvName = new String(sendName.getBytes("GBK"),"UTF-8");
    System.out.println(recvName);
    各位 java 程序员,上段代码中的编码转换有什么问题吗?大部分 recvName 中大部分汉子都可以正常显示,但‘思’和‘怡’两个字乱码。

    5 条回复    2018-03-31 16:47:20 +08:00
    aa6563679
        1
    aa6563679  
       2018-03-31 15:10:13 +08:00 via iPhone
    转成乱码再转回来是会丢失一些汉字的
    Granado
        2
    Granado  
       2018-03-31 15:19:04 +08:00 via Android
    第三行代码应该不是这样用的吧?
    Granado
        3
    Granado  
       2018-03-31 15:58:43 +08:00   ❤️ 1
    说错了,是第二行代码使用方式不对。

    String name="思";
    String sendName = new String(name.getBytes("UTF-8"),"GBK"); // 这里使用错了

    byte[] strBytes = name.getBytes("UTF-8"); // name 这个 String 里面使用的事 char[] 存储的字符。JDK1.8 及其以下,String 内部编码都是 UTF16。所以这里的意思是获取 String 的字节,并将 UTF-16 转成 UTF8,再返回字节数组。

    String sendName = new String(strBytes, "UTF-8"); // 这里要指定的是按什么编码来解码,解码的意思是把字节数组解码成 String 内部编码,即 UTF16。你这里指定的是 GBK,就是把上一步按 UTF8 编码的字节数组按 GBK 来解码成 UTF16,当然就出问题了。

    一般来说,编码间的相互转换都是可逆的,如果出现不能还原,一般都是哪个位置你的理解没对。
    Java 中字符串的解码指其他编码转成 String 的内部编码。编码指 String 的内部编码转换成其他编码。

    Java 9 之后 String 直接用 byte[] 来存储,但是内部编码还是指定了的。具体你可以看源码。
    xgzxy
        4
    xgzxy  
       2018-03-31 16:41:59 +08:00   ❤️ 1
    @Granado 厉害
    lihongjie0209
        5
    lihongjie0209  
       2018-03-31 16:47:20 +08:00
    编码和解码的字符集都不同, 一定会出问题的, 除非二者兼容
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5418 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 09:00 · PVG 17:00 · LAX 02:00 · JFK 05:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.