Java-集合

来源:互联网 发布:菲诗小铺的洗发水知乎 编辑:程序博客网 时间:2024/06/07 13:56

  • 集合和数组
    • 数组
    • 集合
  • 2个公用接口
    • Collection
    • Iterator
  • 3种常用集合
    • Set
    • List
    • Map
  • 集合工具类

这里写图片描述

集合和数组

数组

数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型)

集合

JAVA集合可以存储和操作数目不固定的一组数据。
所有的JAVA集合都位于 java.util包中!
JAVA集合只能存放引用类型的的数据,不能存放基本数据类型.

2个公用接口

Collection

集合接口

boolean add(Object o) :向集合中加入一个对象的引用

void clear() :删除集合中所有的对象,即不再持有这些对象的引用

boolean isEmpty():判断集合是否为空

boolean contains(Object o): 判断集合中是否持有特定对象的引用

Iterartor iterator() : 返回一个Iterator对象,可以用来遍历集合中的元素

boolean remove(Object o):从集合中删除一个对象的引用

int size() :返回集合中元素的数目

Object[] toArray():返回一个数组,该数组中包括集合中的所有元素

关于:Iterator() 和toArray() 方法都用于集合的所有的元素,前者返回一个Iterator对象,后者返回一个包含集合中所有元素的数组。

Iterator

迭代器接口

hasNext(): 判断集合中元素是否遍历完毕,如果没有,就返回true

next() :返回下一个元素

remove():从集合中删除上一个有next()方法返回的元素。

3种常用集合

Set

无序、无重复

HashSet : HashSet类按照哈希算法来存取集合中的对象,存取速度比较快

TreeSet : TreeSet类实现了SortedSet接口,能够对集合中的对象进行排序。

List

有序、可重复

ArrayList() : 代表长度可以改变得数组。可以对元素进行随机的访问,向ArrayList()中插入与 与删除元素的速度慢。

LinkedList(): 在实现中采用链表数据结构。插入和删除速度快,访问速度慢。

最基本的两种检索集合中的所有对象的方法:

1.用for循环和get()方法:

for(int i=0; i<list.size();i++){    System.out.println(list.get(i));}

2.使用 迭代器(Iterator):

Iterator it=list.iterator();while(it.hashNext){    System.out.println(it.next);}

Map

Map 是一种把键对象和值对象映射的集合,它的每一个元素都包含一对键对象和值对象。
Map没有实现Collection接口
从Map集合中检索元素时,只要给出键对象,就会返回对应的值对象。
Map集合中的键对象不允许重复,也就说,任意两个键对象通过equals()方法比较的结果都是false. 但是可以将任意多个键独享映射到同一个值对象上。

1 添加,删除操作:

Object put(Object key, Object value): 向集合中加入元素

Object remove(Object key): 删除与KEY相关的元素

void putAll(Map t): 将来自特定映像的所有元素添加给该映像

void clear(): 从映像中删除所有映射

2 查询操作:

Object get(Object key): 获得与关键字key相关的值

集合工具类

Conllections提供了供Java集合使用的静态方法:

boolean containsKey(Object key): 判断映像中是否存在关键字key

boolean containsValue(Object value): 判断映像中是否存在值value

int size(): 返回当前映像中映射的数量

boolean isEmpty() :判断映像中是否有任何映射


参考目录:
java 中的Set,List,Map

0 0
原创粉丝点击