五、Map接口
Map接口是一种双列集合,它的每个元素都包含一个键对象Key和一个值对象Value,Map里键不允许重复,访问Map的元素,只要指定了键就能找到对应的值。
1.Map接口的声明
public interface Map
2.Map接口的方法
public void put (Object key,Object value)
功能描述:将指定的键和值存入集合并进行映射关联
public Object get(Object key)
功能描述:获得与关键字key相对应的值,如果没有就返回null
public void clear()
功能描述:删除所有映射关系
public boolean isEmpty()
功能描述:判断Map是否还存在映射关系,存在返回true,反之返回false
public void putAll(Map m)
功能描述:将t中包含的元素添加进该方法所在的Map
public int size()
功能描述:返回Map中键值对的个数
public remove(Object key)
功能描述:删除键所对应的映射关系
3.HashMap类
是基于哈希表的Map接口的实现。
4.treeMap
TreeMap类继承AbstractMap类,同时实现了SortedMap,是SortedMap接口的基于红黑树的实现。该类和TreeSet相似,而且处理TreeMap的keySet方法所得到的集合与TreeSet相同。此类保证了映射按照升序顺序排列关键字。
compare To()
比较此对象与指定对象的顺序。如果大于返回正整数,等于返回0,小于返回负整数。抛出类型ClassCastException(如果指定对象的类型无法与该对象进行比较)
Comparable接口
该接口只有Compare To(T o)方法,用comparable接口,需要compara To()方法。
Comparator
该接口不仅有int compare(T o1,T o2)方法,还有boolean equals(Object obj)指示某个其他对象是否等于此Comparator,该接口可以在类外部使用,通过该接口的一个匿名类对象当做参数传递给Collections.sort()方法或Arrays.sort()方法实现排序。
其中compare()比较两个参数,如果大于返回正整数,等于返回0,小于返回负整数。
六、集合的遍历
代码
package test1;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class ListDemo {
public static void main(String[] args) {
List<String> list=new ArrayList();
list.add("hello\nworld\njava");
System.out.println("----迭代器遍历方式-----");
Iterator<String> iterator=list.iterator();
while(iterator.hasNext()) {
String s=iterator.next();
System.out.println(s);
}
System.out.println("----增强for遍历方式-----");
for (String string : list) {
System.out.println(string);
}
System.out.println("----JDK8的forEach遍历方式-----");
list.forEach(s->System.out.println(s));
}
}
执行结果