1. import java.util.ArrayList; 
  2. import java.util.Collection; 
  3. import java.util.Collections; 
  4. import java.util.HashSet; 
  5. import java.util.Iterator; 
  6.  
  7. public class fuxi3_arraylist_hashset 
  8.     public static void main(String[] args) 
  9.     { 
  10.         /************************* JDK1.5增强型for循环 *************************************************/ 
  11.         Collection<String> list = new HashSet<String>();// 多态 
  12.          
  13.         list.add("aaa"); 
  14.         list.add("bbb"); 
  15.         list.add("aaa"); 
  16.         list.add("ddd"); 
  17.         list.add("eee"); 
  18.          
  19.         System.out.println(list.toString());// 打印结果[aaa, ddd, bbb, eee] 
  20.          
  21.         for (Object obj : list)// 遍历list元素,赋给obj 
  22.         { 
  23.             System.out.println(obj); 
  24.         } 
  25.          
  26.         /************************* collection容器ArrayList *************************************************/ 
  27.         ArrayList<Integer> c1 = new ArrayList<Integer>(); 
  28.         c1.add(10); 
  29.         c1.add(20); 
  30.         c1.add(30); 
  31.         c1.add(20); 
  32.         c1.add(50); 
  33.          
  34.         int cs = c1.size();// 容器大小 
  35.         c1.set(05);// 设置容器内指定元素 
  36.         cs = c1.indexOf(10);// 判断对象的位置 
  37.         c1.subList(02);// 截取0-1位置的容器元素,生成新的容器 
  38.         System.out.println(c1); 
  39.         System.out.println(c1.subList(02)); 
  40.          
  41.         Object[] obj = c1.toArray();// 转成数组 
  42.         for (int i = 0; i < obj.length; i++) 
  43.         { 
  44.             System.out.println(obj[i]); 
  45.         } 
  46.          
  47.         /** 
  48.          * ArrayList为什么有两个remove方法? remove(int index) 是子类新添加的! 
  49.          * 如果是父类引用指向子类对象,则找不到子类中新添加的方法。 要想调用子类新添加的方法,需要先转型 
  50.          */ 
  51.         c1.remove(2);// 移除该位置的元素,原容器长度减1 
  52.         c1.remove(Integer.valueOf(20));// 移除第一个该值的元素对象,原容器长度减1,返回类型为布尔类型,结果为true 
  53.         System.out.println(c1); 
  54.          
  55.         int ig = c1.get(0);// 得到位置0的元素 
  56.         boolean bc = c1.isEmpty();// 是否为空 
  57.         bc = c1.contains(15);// 是否包含 
  58.          
  59.         c1.clear();// 清空 
  60.          
  61.         /************************* 容器间ArrayList *************************************************/ 
  62.         ArrayList<String> a1 = new ArrayList<String>(); 
  63.         a1.add("aaa"); 
  64.         a1.add("bbb"); 
  65.         a1.add("ccc"); 
  66.         a1.add("ddd"); 
  67.         a1.add("eee"); 
  68.          
  69.         ArrayList<String> a2 = new ArrayList<String>(); 
  70.         a2.add("bbb"); 
  71.         a2.add("eee"); 
  72.         a2.add("ddd"); 
  73.          
  74.         boolean flag2 = a2.remove("fff"); 
  75.         System.out.println(flag2);// 结果为false 
  76.          
  77.         System.out.println(a1.containsAll(a2));// 是否包含a2所有元素,返回布尔值true 
  78.         System.out.println(a1.retainAll(a2));// 求交集,返回布尔值true 
  79.         System.out.println(a1.addAll(a2));// 添加a2所有元素,返回布尔值true 
  80.         System.out.println(a1.removeAll(a2));// 移除与a2所有元素相同的元素,返回布尔值true 
  81.          
  82.         a1.retainAll(a2);// 求交集,返回布尔值,a1打印结果为:[bbb, ddd, eee] 
  83.         a1.addAll(a2);// 添加,结果为:[aaa, bbb, ccc, ddd, eee, bbb, ddd] 
  84.         a1.removeAll(a2);// 移除,结果为:[aaa, ccc] 
  85.          
  86.         System.out.println(a1); 
  87.          
  88.         /************************* 工具类collections *************************************************/ 
  89.         ArrayList<Integer> aa = new ArrayList<Integer>(); 
  90.         aa.add(13); 
  91.         aa.add(5); 
  92.         aa.add(10); 
  93.         aa.add(53); 
  94.         aa.add(25); 
  95.         aa.add(18); 
  96.          
  97.         Collections.shuffle(aa);// 将容器内对象重新随机排列 
  98.         Collections.sort(aa);// 将容器内对象从小到大排序 
  99.         Collections.reverse(aa);// 将容器内对象倒置排列 
  100.         Collections.fill(aa, 555);// 用特定的对象初始化整个aa 
  101.         Collections.swap(aa, 0, aa.size() - 1);// 容器内对象位置对换 
  102.          
  103.         Integer inc = Collections.max(aa);// 获取容器值最大的对象 
  104.         int ic = Collections.binarySearch(aa, 5);// 二分法查找容器内对象,用之前必须先sort,否则结果返回-1 
  105.          
  106.         System.out.println(ic); 
  107.          
  108.         // /***复制****/ 
  109.         ArrayList<Integer> aa1 = new ArrayList<Integer>(); 
  110.         aa1.add(2); 
  111.         aa1.add(3); 
  112.          
  113.         ArrayList<Integer> aa2 = new ArrayList<Integer>(); 
  114.         aa2.add(12); 
  115.         aa2.add(13); 
  116.         aa2.add(14); 
  117.          
  118.         ArrayList<Integer> aa3 = new ArrayList<Integer>(); 
  119.         aa3.add(15); 
  120.          
  121.         // Collections.copy(aa1, aa2); //将aa2复制到aa1,aa1长度必须大于aa2,否则报错 
  122.         Collections.copy(aa2, aa3);// 将aa3复制到aa2,长度不够的保留原对象,打印结果:[15, 13, 14] 
  123.         System.out.println(aa1); 
  124.         System.out.println(aa2); 
  125.     } 
  126.