标签:
import java.util.Arrays;p
ublic class ArrayAsAReference{
public static void main(String[] args)
{ int[] arr = null;
System.out.println(arr);
arr = new int[]{1, 2, 3, 4}; // 静态创建数组对象
System.out.println(Arrays.toString(arr));
int[] prices;
prices = new int[5]; // 动态创建数组对象
System.out.println(Arrays.toString(prices));
System.out.println(); //使用普通循环遍历数组对象
for(int i = 0; i < prices.length; i++) {
System.out.println("prices[" + i + "] = " + prices[i]);
}
System.out.println(); //使用foreach循环遍历数组对象
for (int price : prices)
{
System.out.println("price:" + price);
}
}
}
然后在cmd.exe里用javac去编译,出现了如下的错误:
在编译的时候,如果没有用-encoding参数指定java源程序的编码格式,则javac.exe认为源代码的编码格式是操作系统默认的编码格式,所以就会用按照操作系统默认的编码格式去处理源代码。上面由于windows下默认编码格式是GBK,编译的时候没有javac就会把ArrayAsAReference.java当成GBK编码的文件,但是实际上ArrayAsAReference.java是utf-8格式,所以转换就出现了错误。
javac编译源代码的是时候会先把源程序的编码格式转化为java内部采用的unicode格式,再把unicode格式的源程序装入内存中。之后编译,编译生成.class类文件,此时.class文件也是unicode编码的,它暂放在内存中,最后javac将unicode编码的class文件保存到操作系统中形成.class文件。
因此,编码问题只会出现在编译阶段,而在运行阶段用java命令去执行class文件的时候从来不会出现编码问题,因为编译后的class文件必然是unicode编码的。
标签:
原文地址:http://www.cnblogs.com/zhangzl419/p/5529493.html