数组:

。(且存放的类型必须一致)

 

集合:

 

  1. 存放其它对象的对象,且只能是对象(即引用数据类型) 由数组的缺点引出集合(长度 不可变且连续)
  2. 所有Java集合类都位于java.util包中

 

为单值(单个值)

 

.

为双值(键值对)

 

Map是一种把键对象和值对象进行映射的集合,它的每一个元素都包含一对键对象和值对象。向Map集合中加入元素时,必须提供一对键对象和值对象,从Map集合中检索元素时,只要给出键对象,就会返回对应的值对象。Map集合中的键对象不允许重复,如以相同的键对象加入多个值对象,第一次加入的值对象将被覆盖

 

Map:

 

键不可以重复,键确定,值确定(值可以重复)

 

Put(key,value):插入:相同的key会被最新的替换,值重复没关系,key允许为null或者值为null

 

get(key):获取key对应的值

 

 

Map接口中定义了Entry接口

 

为什么Set、List集合可以调用iterator方法,然后使用迭代器进行遍历,而Map集合不能使用迭代器遍历?

 

因为Set、List集合都继承了Collection接口,而Collection接口又继承了Iterable接口,Iterable接口中提供了iterator方法,该方法可以返回一个迭代器,用来遍历集合。Map集合则没有继承该接口。

  

Java中集合主要分为三种类型:

 

无序,并且没有重复对象。不支持null(写实例时要先完善hashcode 和equals,是根据这个去重!)

 

有序(放入的先后的次序), 可重复。允许null值

集合中的每一个元素包含一对键对象和值对象,集合中没有重复的键

对象,值对象可以重复

SortedSet:已经完成排序(修改其中数据后不会再次排序了)

SortedMap:对键排好序

  

顺序表:

ArrayList: 数组实现(插入删除效率低,查找效率高)

LinkedList:链表实现(插入删除效率高,查找效率低)

VectorList:适用于多线程的表,类似ArrayList,但是效率低一些

 

Hash表:

HashSet:按照哈希算法来存取集合中的对象,存取速度比较快(写实例时要先完善hashcode 和equals,是根据这个去重!)

TreeSet: TreeSet实现了SortedSet接口,能够对集合中的对象进行排序,不支持null

HashMap: 按哈希算法来存取键对象,有很好的存取性能

TreeMap:  实现了SortedMap接口,能对键对象进行排序

 

Iterator:默认初始位置在最左侧

 

对象如果没有重写toString方法,则默认是Object的方法返回值: 类名@哈希值

 

输出语句怎么把int转化为String类型:+ “ ”  通过+链接强制转换一下字符串

 

每个对象都自带equals()和hasCode()方法。是Object(所有类的超类)自带的

 

为什么要用equals,因为set不能重复,谁不能重复?自己定义的类的对象不能,那就必须该对象要用equals判断,且要重写,因为它不是基本类型,是类类型,而用hashCode是为了减少循环次数。hashCode和equals一般是配套重写的,一般是先判断hashCode再equals