public static void main(String[] args) {
final int []k = new int[1] ; 这里不能是int k ;因为必须是final ,但是final数组表示不能引用另外一个数组(引用类型),数组中的元素可以自由更改。
Date [] date = new Date[100];
for(int i = 0 ;i<date.length;i++)
date[i]=new Date(){
public int compareTo(Date other){
k [0]++ ;
return super.compareTo(other);
}
};
Arrays.sort(date);
System.out.println(Arrays.toString(date));
System.out.println(k[0]);
}
Arrays.sort对数组排序的时候,如果。数组类型是引用类型,就必须实现Comparable接口,覆盖compareTo方法,才能比较。
局部类方法只能引用定义为final的局部变量。
为什么匿名内部类和局部内部类只能访问final变量:
是变量的作用域的问题,因为匿名内部类是出现在一个方法的内部的,如果它要访问这个方法的参数或者方法中定义的变量,则这些参数和变量必须被修饰为final。因为虽然匿名内部类在方法的内部,但实际编译的时候,内部类编译成Outer.Inner,这说明内部类所处的位置和外部类中的方法处在同一个等级上,外部类中的方法中的变量或参数只是方法的局部变量,这些变量或参数的作用域只在这个方法内部有效。因为编译的时候内部类和方法在同一级别上,所以方法中的变量或参数只有为final,内部类才可以引用。
当变量是final时,若是引用类型,由于其引用值不变(即:永远指向同一个对象),因而:其复制品与原始的引用变量一样,永远指向同一个对象(由于是final,从而保证:只能指向这个对象,再不能指向其它对象),达到:局部内部类中访问的复制品与方法代码中访问的原始对象,永远都是同一个即:语义效果是一样的.否则:当方法中改原始变量,而局部内部类中改复制品时,就无法保证:复制品与原始变量保持一致了(因此:它们原本就应该是同一个变量.)
一句话:这个规定是一种无可奈何.也说明:程序设计语言的设计是受到实现技术的限制的.这就是一例. 因为:我就看到不少人都持这种观点:设计与想法是最重要的,实现的技术是无关紧要的,只要你作出设计与规定,都能实现.