刚刚照着书(Java)用Notepad++把代码敲了一遍,如下:
public class FloatTest{
public static void main(String[] args){
float af = 5.2345556f;
//下面将看到af的值已经发生了改变
System.out.println(af);
double a = 0.0;
double c = Double.NEGATIVE_INFINITY;
float d = Float.NEGATIVE_INFINITY;
//看到float和double的负无穷大是相等的
System.out.println(c == d);
//0.0除以0.0将出现非数
System.out.println(a / a);
//两个非数之间是不相等的
System.out.println(a / a == Float.NaN);
//所有正无穷大都是相等的
System.out.println(6.0 / 0 == 555.0/0);
//负数除以0.0得到负无穷大
System.out.println(-8 / a);
//下面代码将抛出除以0的异常
//System.out.println(0 / 0);
}
}
发现了件有趣的事情~~
①右键新建文本文档,通过重命名为FloatTest.java
编译没有问题
②这次,偶然地在Notepad++当前窗口通过(文件–新建)方式创建
编译的时候出了问题
使用的是UTF-8编码
同一个编辑工具不同的创建方式也能出现问题。
先来了解这个错误(编码GBK的不可映射字符)是怎么回事,于是找了些解释:
由于JDK是国际版的,我们在用javac.exe编译时,编译程序首先会获得我们操作系统默认采用的编码格式(也即在编译java程序时,若我们不指定源程序文件的编码格式,JDK首先获得操作系统的file.encoding参数(它保存的就是操作系统默认的编码格式,如WIN2k,它的值为GBK),然后JDK就把我们的java源程序从file.encoding编码格式转化为JAVA内部默认的UNICODE格式放入内存中。然后,javac.exe把转换后的UNICODE格式的文件进行编译成.class类文件,此时.class文件是UNICODE编码的,它暂放在内存中,紧接着,JDK将此以UNICODE编码的编译后的class文件保存到我们的操作系统中形成我们见到的.class文件。对我们来说,我们最终获得的.class文件是内容以UNICODE编码格式保存的类文件,它内部包含我们源程序中的中文字符串,只不过此时己经由file.encoding格式转化为UNICODE格式了。
当我们不加设置就编译时,相当于使用了参数:javac -encoding gbk *.java,当然就会出现不兼容的情况。
还看了,有人把编码设置为ANSI,编译也不会报错。
尝试之后,果真如此。可是为什么ANSI可以,UTF-8就不行呢?
后来又有另外一个想法——我的这些中文字符全都在注释里面,照理说不会报错呀,不是说好编译时直接忽略掉吗?为此我特地编译了两个版本(有注释与无注释),两个.class文件大小一致。
总结:
①两个不同的创建文件方式有什么区别?
编码不同,一个ANSI,另一个根据工具的设置给定。
②ANSI编码可以通过编译,UTF-8不能通过,为什么?
ANSI引用我的系统默认编码GBK
③编译时忽略注释部分,为什么还会报错?
…..