打字猴:1.70044421e+09
1700444210
1700444211 }
1700444212
1700444213 c1是通过ArrayList的构造函数创建的,c2是通过列表的subList方法创建的,然后c2又增加了一个元素C,现在的问题是输出的结果是什么呢?列表c与c1、c2之间是什么关系呢?
1700444214
1700444215 别忙着回答这个问题,我们先来回想一下String类的subString方法,看看它是如何工作的,代码如下:
1700444216
1700444217 public static void main(String[]args){
1700444218
1700444219 String str=“AB”;
1700444220
1700444221 String str1=new String(str);
1700444222
1700444223 String str2=str.substring(0)+“C”;
1700444224
1700444225 System.out.println(“str==str1?”+str1.equals(str1));
1700444226
1700444227 System.out.println(“str==str2?”+str.equals(str2));
1700444228
1700444229 }
1700444230
1700444231 很明显,str与str1是相等的(虽然不是同一个对象,但用equals方法判断是相等的),但它们与str2不相等,这毋庸置疑,因为str2在对象池中重新生成了一个新的对象,其表面值是ABC,那当然与str和str1不相等了。
1700444232
1700444233 说完了subString的小插曲,现在回到List是否相等的判断上来。subList与subString的输出结果是一样的吗?让事实说话,运行结果如下:
1700444234
1700444235 c==c1?false
1700444236
1700444237 c==c2?true
1700444238
1700444239 很遗憾,与String类刚好相反,同样是一个sub类型的操作,为什么会相反呢?仅仅回答“为什么”似不足以平复我们的惊讶,下面就从最底层的源代码来进行分析。
1700444240
1700444241 c2是通过subList方法从c列表中生成的一个子列表,然后c2又增加了一个元素,可为什么增加了一个元素还会相等呢?我们来看subList源码:
1700444242
1700444243 public List<E>subList(int fromIndex, int toIndex){
1700444244
1700444245 return(this instanceof RandomAccess?
1700444246
1700444247 new RandomAccessSubList<E>(this, fromIndex, toIndex):
1700444248
1700444249 new SubList<E>(this, fromIndex, toIndex));
1700444250
1700444251 }
1700444252
1700444253 subList方法是由AbstractList实现的,它会根据是不是可以随机存取来提供不同的SubList实现方式,不过,随机存储的使用频率比较高,而且RandomAccessSubList也是SubList子类,所以所有的操作都是由SubList类实现的(除了自身的SubList方法外),那么,我们就直接来看SubList类的代码:
1700444254
1700444255 class SubList<E>extends AbstractList<E>{
1700444256
1700444257 //原始列表
1700444258
1700444259 private AbstractList<E>l;
[ 上一页 ]  [ :1.70044421e+09 ]  [ 下一页 ]