zoukankan      html  css  js  c++  java
  • 警告:编码 utf8 的不可映射字符 ANT编译java文件的问题

    http://www.blogjava.net/jerry-zhaoj/archive/2009/05/20/271695.html

    这是因为:由于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,当然就会出现不兼容的情况。


    解决办法:
    <javac
    destdir="${build.dir}/classes" debug="true" deprecation="false" optimize="false"
    failonerror="true" encoding="utf-8">

    <src path="${src.dir}" />
    <classpath refid="classpath" />

    </javac>

    javac里面加encoding参数
    编码方式为实际编码即可

    I'm falling off the sky all alone.The courage inside is gonna break the fall. Nothing can dim my light within. I am That I am 程序 = 数据结构 + 算法
  • 相关阅读:
    Tensorflow io demo (待)
    tf.Dataset
    tf.estimator
    并发队列
    Callable的Future模式
    hadoop之HDFS介绍
    线程池
    并发工具类
    并发编程
    初学hadoop之hadoop集群搭建
  • 原文地址:https://www.cnblogs.com/IamThat/p/2965491.html
Copyright © 2011-2022 走看看