要使用这两个函数,在函数底层调用的是对象的equals()方法进行比较,因此集合中的对象应该重写equals()这个方法。
使用迭代器来遍历集合,不用根据下标一个个遍历,for each就是一个迭代器原理
迭代器对所有Collection通用,因为Iterable是Collection的父接口
Collection c=new ArrayList();
Iterator it=c.iterator();
if(it.hasNext()){
Object o=it.next();
}
当集合结构发生改变时:必须重新获取迭代器,否则会出现异常
因此,在迭代过程中不能调用collection.remove(),但是可以调用iterator.remove(),通过迭代器对象来改变集合元素是没问题的。
常用方法:
集合底层是一个数组结构的对象
ArrayList对象的扩容:是重新建一个更大的对象,然后将就对象中的内容拷贝过去,因此对于ArrayList可以做的优化就是在最初创建的时候就给一个合适的大小,尽量减少底层扩容的次数
底层是一个双向链表
用泛型指定只能存储的类型
List
Map底层中存储的对象是一个Key和value结合的节点对象,Node
Node
两个属性:key 和value
两个方法: getKey()、getValue
Map.entrySet()返回的就是以Map.Entry
HashMap底层是一个哈希表/散列表,
哈希表是一个数组和链表结合的结构,首先是是一个node
node
node
final K key;
V value;
final int hash;//哈希值
node
}
每一个node对象都有一个确定的哈希值,根据hashnode()方法得出。
HashMap的put的实现原理:
因此,如果HashMap中放置的自定义类型,得重写hashnode()和equals()方法。
HashMap构造
HashMap 是一种常用的数据结构,一般用来做数据字典或者 Hash 查找的容器。普通青年一般会这么初始化:
HashMap
map.put(“name”, “test”);
map.put(“age”, “20”);
看完这段代码,很多人都会觉得这么写太啰嗦了,文艺青年一般这么来了:
HashMap
{
put(“name”, “test”);
put(“age”, “20”);
}
};
底层结构是红黑树,节点node有五个属性(key,value,left,right,parent),节点有自身Kv和指向相关节点的引用。
TreeMap中的key根据排序规则可以进行排序形成红黑树,因此存放的对象必须可以比较,实现排序规则,有两种方式:
Class Student implement Comparable<Student>{
private String name;
@Override
public int compareTo(Student s){
return this.name.compareTo(s.name);
}
}
TreeMap<Student> students=new TreeMap<>(new Comparator<Student>(){
public int compare(Student s1,Student s2){
return s1.name.compareTo(s2.name);
}
});
两种方式的比较:
在比较规则不经常发生改变时,一般实现comparable接口,若比较规则有多个或经常改变,一般使用传比较器对象的方式。
常用方法: