个人小结:集合框架工具类中常用的有Collections和Arrays,他们提供了很多封装好的静态方法,专门用于对集合数据的操作,非常方便快捷。
一、Collections
Collections是对集合框架的一个工具类。它的出现给集合操作提供了更多的功能。这个类不需要创建对象,内部提供的都是静态方法。
常见方法:
1、max(Collection extends T> coll) :根据元素的自然顺序,返回给定 collection 的最大元素。
2、max(Collection extends T> coll, Comparator super T> comp) : 根据指定比较器产生的顺序,返回给定 collection 的最大元素。
3、binarySearch(List extends Comparable super T>> list, T key) : 使用二分搜索法搜索指定列表,以获得指定对象。
4、binarySearch(List extends T> list, T key, Comparator super T> c) :使用二分搜索法搜索指定列表,以获得指定对象。
5、fill(List super T> list, T obj) :使用指定元素替换指定列表中的所有元素。
6、replaceAll(List
7、swap(List> list, int i, int j) : 在指定列表的指定位置处交换元素
8、sort(List
9、sort(List
10、reverse(List> list) :反转指定列表中元素的顺序。
11、reverseOrder() :返回一个比较器,它强行逆转实现了 Comparable 接口的对象 collection 的自然顺序。
12、reverseOrder(Comparator
Collections与Collection的区别:
1、Collection是java.util包下的集合接口,是多种集合结构的根接口。Collection提供了对集合对象进行基本操作的通用接口方法,JDK 不提供此接口的任何直接实现,但它提供更具体的子接口(如 Set和 List)的实现。Collection的意义在于为各种具体的集合对象提供最大化的统一操作方式,如插入、删除、判断一个元素是否其成员、遍历等基本操作。
2、Collections是java.util包下一个类,此类完全由在 collection 上进行操作或返回 collection 的静态方法组成。这些方法可以实现对各类集合对象的搜索,排序,线程安全化等操作。它包含在 collection上操作的多态算法,即“包装器”,包装器返回由指定 collection 支持的新 collection,以及少数其他内容。
示例:
import java.util.*;
class CollectionsDemo
{
public static void main(String[] args)
{
//sortDemo();//排序
//maxDemo();//求最大值
binarySearchDemo();//二分查找
}
//二分查找
public static void binarySearchDemo()
{
List list = new ArrayList ();
list.add("abcd");
list.add("aaaa");
list.add("z");
list.add("kkkkh");
list.add("ggg");
list.add("a");
Collections.sort(list,new StrLenComparator());
sop(list);
//int index = Collections.binarySearch(list,"ggg");
//sop("index="+index);
//int index2 = halfSearch(list,"ggg");
//sop("index2="+index2);
int index3 = halfSearch2(list,"aaaa",new StrLenComparator());
sop("index3="+index3);
}
//求最大值
public static void maxDemo()
{
List list = new ArrayList ();
list.add("abcd");
list.add("aaaa");
list.add("z");
list.add("kkkkh");
list.add("ggg");
list.add("a");
sop(list);
String max = Collections.max(list/*,new StrLenComparator()*/);
sop("max="+max);
}
//排序
public static void sortDemo()
{
List list = new ArrayList ();
list.add("abcd");
list.add("aaaa");
list.add("z");
list.add("kkkk");
list.add("ggg");
list.add("a");
sop(list);
//Collections.sort(list);
Collections.sort(list,new StrLenComparator());
sop(list);
}
//封装打印功能
public static void sop(Object obj)
{
System.out.println(obj);
}
}
//实现比较器接口
class StrLenComparator implements Comparator
{
public int compare(String s1,String s2)
{
if (s1.length()>s2.length())
return 1;
if (s1.length()
练习:
import java.util.*;
class StrComparator implements Comparator//实现比较器接口
{
public int compare(String s1,String s2)
{
/*
int num = s1.compareTo(s2);
if(num>0)
return -1;
if(num<0)
return 1;
return num;
*/
return s2.compareTo(s1);
}
}
//自定义一个比较字符串长度的比较器
class StrLenComparator implements Comparator
{
public int compare(String s1,String s2)
{
if (s1.length()>s2.length())
return 1;
if (s1.length()新字符子串替换旧字符子串
orderDemo();//排序
}
//排序
public static void orderDemo()
{
//TreeSet ts = new TreeSet(Collections.reverseOrder()); //new StrComparator
TreeSet ts = new TreeSet(Collections.reverseOrder(new StrLenComparator()));
ts.add("abcd");
ts.add("aaaa");
ts.add("z");
ts.add("kkkkh");
ts.add("ggg");
ts.add("a");
Iterator it = ts.iterator();
while (it.hasNext())
{
sop(it.next());
}
}
//新字符子串替换旧字符子串
public static void replaceAllDemo()
{
List list = new ArrayList ();
list.add("abcd");
list.add("aaaa");
list.add("z");
list.add("kkkkh");
list.add("ggg");
list.add("a");
sop(list);
Collections.replaceAll(list,"ggg","pp");
Collections.reverse(list);
sop(list);
}
/*
练习。fill方法可以将list集合中所有元素替换成指定元素,
将list集合中部分元素替换成指定元素。
*/
public static void fillDemo()
{
List list = new ArrayList ();
list.add("abcd");
list.add("aaaa");
list.add("z");
list.add("kkkkh");
list.add("ggg");
list.add("a");
sop(list);
Collections.fill(list,"pp");
sop(list);
}
//封装打印功能
public static void sop(Object obj)
{
System.out.println(obj);
}
}
运行结果:
import java.util.*;
class ArraysDemo
{
public static void main(String[] args)
{
//int[] arr = {2,4,5};
//sop(Arrays.toString(arr));
String [] arrStr = {"abc","cc","kkkk"};
//把数组变成list集合有什么好处?
/*
可以使用集合的思想和方法来操作数组中的元素。
*/
List list =Arrays.asList(arrStr);
//sop("contains:"+list.contains("cc"));
//list.add("qq"); //UnsupportedOperationException,
//sop(list);
int[] nums = {2,4,5};
List li = Arrays.asList(nums);
Integer[] in = {3,4,5};
List li2 = Arrays.asList(in);
/*
如果数组中的元素都是对象,那么变成集合时,数组中的元素就直接
转成集合中的元素。
如果数组中的元素都是基本数据类型,那么会将该数组作为集合中的
元素存在。
*/
sop(li);
sop(li2);
}
public static boolean myContains(String[] arr,String key)
{
for (int x=0; x
运行结果:
import java.util.*;
class CollectionToArray
{
public static void main(String[] args)
{
ArrayList al = new ArrayList();
al.add("abc1");
al.add("abc2");
al.add("abc3");
//指定长度和size相等的数组
String [] arr = al.toArray(new String[al.size()]);
System.out.println(Arrays.toString(arr));
}
}
运行结果:
示例:
import java.util.*;
class ForEachDemo
{
public static void main(String[] args)
{
ArrayList al = new ArrayList();
al.add("abc1");
al.add("abc2");
al.add("abc4");
for (String s : al)
{
s = "kk";
System.out.println(s);
}
//System.out.println(al);
/*
Iterator it = al.iterator();
while (it.hasNext())
{
System.out.println(it.next());
}
*/
//高级for循环对数组的操作
int[] arr = {3,5,1};
for (int i : arr )
{
System.out.println("i:"+i);
}
HashMap hm = new HashMap();
hm.put(1,"a");
hm.put(2,"b");
hm.put(3,"c");
//高级for循环对map集合的操作1
Set keySet = hm.keySet();
for (Integer i : keySet)
{
System.out.println(i+"::"+hm.get(i));
}
//高级for循环对map集合的操作2
Set> entrySet = hm.entrySet();
for (Map.Entry me : entrySet )
{
System.out.println(me.getKey()+":::"+me.getValue());
}
}
}
运行结果:
2、可变参数(...):
用到函数的参数上,当要操作的同一个类型元素个数不确定的时候,可是用这个方式,这个参数可以接受任意个数的同一类型的数据。
和以前接收数组不一样的是:
以前定义数组类型,需要先创建一个数组对象,再将这个数组对象作为参数传递给函数。现在,直接将数组中的元素作为参数传递即可。底层其实是将这些元素进行数组的封装,而这个封装动作,是在底层完成的,被隐藏了。所以简化了用户的书写,少了调用者定义数组的动作。
如果在参数列表中使用了可变参数,可变参数必须定义在参数列表结尾(也就是必须是最后一个参数,否则编译会失败。)。
示例:
import java.util.*;
class ParamMethodDemo
{
public static void main(String[] args)
{
//show(3,4);
//虽然少定义了多个方法,
//但是每次都要定义一个数组,作为实际参数。
/*
int[] arr = {3,4};
show(arr);
int[] arr1 = {3,4,5};
show(arr1);
*/
/*
可变参数,其实就是上一种数组参数的简写形式。
不用每次都手动的建立数组对象。只要将操作的元素
作为参数传递即可。
隐式滴将这些参数封装成了数组。
*/
show("haha",2,2,3,4,5,6);
//show(2,2,3,4,5,6,4,5,6,75);
}
public static void show(String str,int... arr)//使用可变参数
{
System.out.println(str);
for(int i : arr)
{
System.out.println(i);
}
}
}
运行结果:
3、静态导入:
就是导入类中的所有静态成员,简化静态成员的书写。
写法:
import static java.util.Arrays.*;//导入的是Arrays这个类中的所以静态成员。
没加static导入的是类,加上static导入的全是某一个类中所以的静态成员。这样写在调用该类的静态方法时可以不用再写类名。如:Arrays.sort(数组);就可以直接写sort(数组);
注意:
当导入的两个类中有同名成员时,需要在成员前加上相应的类名。
当类名重名时,需要指定具体的包名。当方法重名时,指定具体所属的对象或者类。
示例:
import java.util.*;
import static java.util.Arrays.*;//导入的是Arrays这个类中的所有静态成员。
import static java.lang.System.*;//导入了System类中所有的静态成员。
class StaticImport extends Object
{
public static void main(String[] args)
{
int[] arr = {3,1,5};
sort(arr);//省略了Arrays.
int index = binarySearch(arr,1);
/*System.*/out.println(Arrays.toString(arr));//省略了System.
System.out.println("index="+ index);
}
}
运行结果: