zoukankan      html  css  js  c++  java
  • 字符编码问题

    1. 字符编码

    ASCII编码采1字节,8bit,最多有256个字符ASCII编码无法适应其他语言的字符,后来有了扩展编码(采用变长ASCII编码的形式)。

    GBK,GB2132,GB18030中文简体

    ISO8859西欧语言

    BIG5繁体中文

    1.1. unicode编码


    为了统一不同的字符集,不断扩充,直到包含所有字符。

    编码方案

    • UTF-8,兼容ASCII码,采用变长的方式来存储字符,使用1~4个字节来存储。

    • UTF-16,采用变长的方式来存储字符,使用2~4个字节来存储。

    • UTF-32,使用4个字节来存储所有的字符。
      (windows系统下的ANSI编码在不同的操作系统代表不同的字符集,简体中文为GBK,繁体中文为BIG5)

    2. windowsCMD窗口编码格式设置:

    CHCP是一个计算机指令,能够显示或设置活动代码页编号

    1. CHCP 65001 UTF-8代码页
    2. CHCP 950 繁体中文
    3. CHCP 936 简体中文默认的GBK

    由于WINDOWS的默认编码格式为GBK,命令行也为GBK编码。
    可以变为UTF-8编码。

    3.JAVA控制台编译乱码

    JDK是国际版的,在编译的时候,如果我们没有用-encoding参数指定我们的JAVA源程序的编码格式,则javac.exe首先获得我们操作系统默认采用的编码格式,也即在编译java程序时,若我们不指定源程序文件的编码格式,JDK首先获得操作系统的file.encoding参数(它保存的就是操作系统默认的编码格式,如WIN2k,它的值为GBK),然后JDK就把我们的java源程序从file.encoding编码格式转化为JAVA内部默认的UNICODE格式放入内存中。然后,javac把转换后的unicode格式的文件进行编译成.class类文件,此时.class文件是UNICODE编码的,它暂放在内存中,紧接着,JDK将此以UNICODE编码的编译后的class文件保存到我们的操作系统中形成我们见到的.class文件。对我们来说,我们最终获得的.class文件是内容以UNICODE编码格式保存的类文件,它内部包含我们源程序中的中文字符串,只不过此时它己经由file.encoding格式转化为UNICODE格式了。当我们不加设置就编译时,相当于使用了参数:javac -encoding gbk XX.java,当然就会出现不兼容的情况。

    解决方法:系统环境变量添加“JAVA_TOOL_OPTIONS”变量,值为“-Dfile.encoding=UTF-8”

  • 相关阅读:
    HDU
    POJ
    POJ
    POJ
    POJ
    POJ
    POJ
    SPFA算法——最短路径
    POJ1251 Jungle Roads Kruskal+scanf输入小技巧
    MongoDB--关于数据库及选择MongoDB的原因
  • 原文地址:https://www.cnblogs.com/innndown/p/12361780.html
Copyright © 2011-2022 走看看