当前位置: 代码迷 >> J2SE >> ,编译时出现“警告:编码 GBK 的不可映射字符”,怎么处理
  详细解决方案

,编译时出现“警告:编码 GBK 的不可映射字符”,怎么处理

热度:259   发布时间:2016-04-24 01:44:43.0
求助,编译时出现“警告:编码 GBK 的不可映射字符”,怎么办?
在网上搜了下,说是在javac -encoding UTF-8 *.java就Ok了。但是我加上后,又出现“非法字符”的错误。求教是怎么回事,怎么解决?
代码:
Java code
import java.util.Arrays;public class Num2Rmb{    private String[] hanArr = {"零","壹","贰","叁","肆","伍","陆","柒","捌","玖"};    private String[] unitArr = {"拾","佰","仟"};    /**    * 把一个浮点数分解成整数部分和小数部分字符串    * @param num需要被分解的浮点数    * @return分解出来的整数部分和小数部分。第一个数组元素是整数部分,第二个数组元素是小数部分    */    private String[] divide(double num)    {        //将一个浮点数强制类型转换为long,即得到它的整数部分        long zheng = (long)num;        //浮点数减去整数部分,得到小数部分,小数部分乘以100后再取整得到两位小数        long xiao = Math.round((num - zheng)*100);        return new String[]{zheng + "",String.valueOf(xiao)};        }    /**    * 把一个四位的数字字符串变成汉字字符串    * @param numStr 需要被转换的四位的数字字符串    * @return 四位的数字字符串被转换成的汉字字符串    */    private String toHanStr(String numStr)    {        String result = "";        int numLen = numStr.length();        //依次遍历数字字符串的每一位数字        for(int i = 0;i < numLen;i ++ )        {            //把char型数字转换成的int型数字,因为它们的ASCII码值恰好相差48            //因此把char型数字减去48得到int型数字,例如'4'被转换成4.            int num = numStr.charAt(i) - 48;            //如果不是最后一位数字,而且数字不是零,则需要添加单位(仟、佰、拾)            if(i != numLen - 1 && num != 0)            {                result += hanArr[num] + unitArr[numLen - 2 - i];                }            //否则不要添加单位            else            {                result += hanArr[num];                }            }        return result;        }public static void main(String[] args){    Num2Rmb nr = new Num2Rmb();    //测试把一个浮点数分解成整数部分和小数部分    System.out.println(Arrays.toString(nr.divide(236711125.123)));    //测试把一个四位的数字字符串变成汉字字符串    System.out.println(nr.toHanStr("6109"));    }    }


------解决方案--------------------
如果你在eclipse 或者netbeans 里面编写,出现此类问题,就要去改IDE的配置,改一下编码格式。
如果你在ultraedit 里面编写的,改一下ultraedit的编码格式。我前几天也碰到了这个问题,是再ultraedit里面遇到的。如果楼主不明白,可以再问,半小时内,我在线等着哈……
------解决方案--------------------
你的文件使用什么编码
-encoding 后面跟上什么。
------解决方案--------------------
如果你是用EditPlus编译器的话~~~解决方法如下:
 左上角 文件—另存为 打开之后,最下方有个“编码”的选项 把它换成“ANSI”
 此问题可解决~~~
------解决方案--------------------
在MYCLIPSE中将Text file encoding设置为UTF-8,再进行编译
------解决方案--------------------
用文本编辑器打开,另存为,在文件名下面一般有个编码格式,你选择“ANSI”后再试试看。
------解决方案--------------------
你用中断控制台编译的吧,Windows默认编码是GBK,汉语繁体的壹","贰","叁","肆","伍","陆","柒","捌","玖,可能有的超出的GBK编码范围。不要用终端编译,终端编译改编码很麻烦的。用IDE编译,设置编码UTF-8应该就可以了。
  相关解决方案