java知识之----集合

集合主要分为二大类,一种为单列集合,所有的单列集合的最顶层接口为 :java.util.Collection

任意的单列集合都可以使用Collection接口中的方法

public boolean add(E e):  把给定的对象添加到当前集合中 。
public void clear() :清空集合中所有的元素。
public boolean remove(E e): 把给定的对象在当前集合中删除。
public boolean contains(E e): 判断当前集合中是否包含给定的对象。
public boolean isEmpty(): 判断当前集合是否为空。
public int size(): 返回集合中元素的个数。
public Object[] toArray(): 把集合中的元素,存储到数组中。

如何遍历集合中的元素:

1、java.util.Iterator接口:迭代器(对集合进行遍历)

boolean hasNext() : 判断集合中还有没有下一个元素,有就返回true,没有就返回false

E next() 返回迭代的下一个元素。

取出集合中的下一个元素 Iterator迭代器是一个接口,我们无法直接使用,需要使用Iterator接口的实现类对象,获取实现类的方式比较特殊 Collection接口中有一个方法,叫iterator(),这个方法返回的就是迭代器的实现类对象 Iterator<E> iterator() 返回在此 collection 的元素上进行迭代的迭代器。

使用步骤:

1.使用集合中的方法iterator()获取迭代器的实现类对象,使用Iterator接口接收(多态)

2.使用Iterator接口中的方法hasNext判断还有没有下一个元素

3.使用Iterator接口中的方法next取出集合中的下一个元素

public class Demo01Iterator {
    public static void main(String[] args) {
        //创建一个集合对象
        Collection<String> coll = new ArrayList<>();
        //往集合中添加元素
        coll.add("姚明");
        coll.add("科比");
        coll.add("麦迪");
        coll.add("詹姆斯");
        coll.add("艾弗森");
   Iterator<String> it = coll.iterator();
  while(it.hasNext()){
            String e = it.next();
            System.out.println(e);
        }
  }
}

2、增强for循环:底层使用的也是迭代器,使用for循环的格式,简化了迭代器的书写 。它是JDK1.5之后出现的新特性。

Collection<E>extends Iterable<E>:所有的单列集合都可以使用增强for public interface Iterable<T>实现这个接口允许对象成为 "foreach" 语句的目标。

public class TestForeach {
    public static void main(String[] args) {
        demo();
    }

    //使用增强for循环遍历集合
    private static void demo() {
        ArrayList<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");
        list.add("ddd");
        for(String s : list){
            System.out.println(s);
        }
    }

}

单列集合:

一:List:

1.有序的集合,存储元素和取出元素的顺序是一致的(存储123 取出123)

2.有索引,包含了一些带索引的方法

3.允许存储重复的元素

List接口中带索引的方法(特有)

- public void add(int index, E element): 将指定的元素,添加到该集合中的指定位置上。

- public E get(int index):返回集合中指定位置的元素。

- public E remove(int index): 移除列表中指定位置的元素, 返回的是被移除的元素。

- public E set(int index, E element):用指定元素替换集合中指定位置的元素,返回值的更新前的元素。

ArrayList:底层的实是一个动态的数组,是非线程安全的,它具有增删慢查询快的特点。

LinkedList:底层的数据结构为链表,同样非线程安全的,具有查询慢增删快的特点。其中里边包含了大量操作首尾元素的方法。

二:Set

1.不允许存储重复的元素

2.没有索引,没有带索引的方法,也不能使用普通的for循环遍历

HashSet:

1.不允许存储重复的元素

2.没有索引,没有带索引的方法,也不能使用普通的for循环遍历

3.是一个无序的集合,存储元素和取出元素的顺序有可能不一致

4.底层是一个哈希表结构(查询的速度非常的快)

注意:存储的元素(String,Integer,...Student,Person...),必须重写hashCode方法和equals方法

LinkedHashSet: 底层是一个哈希表(数组+链表/红黑树)+链表:多了一条链表(记录元素的存储顺序),保证元素有序。

工具类:Collections是集合工具类,用来对集合进行操作

- public static <T> boolean addAll(Collection<T> c, T... elements):往集合中添加一些元素。

- public static void shuffle(List<?> list) 打乱顺序:打乱集合顺序。

-public static <T> void sort(List<T> list):将集合中元素按照默认规则排序。

(sort(List<T> list)使用前提是被排序的集合里边存储的元素,必须实现Comparable,重写接口中的方法compareTo定义排序的规则)

-public static <T> void sort(List<T> list,Comparator<? super T> ):将集合中元素按照指定规则排序。

双列集合

Map (java.util.Map<k,v>)

1.Map集合是一个双列集合,一个元素包含两个值(一个key,一个value)
2.Map集合中的元素,key和value的数据类型可以相同,也可以不同
3.Map集合中的元素,key是不允许重复的,value是可以重复的
4.Map集合中的元素,key和value是一一对应

 HashMap

1.HashMap集合底层是哈希表:查询的速度特别的快
        哈希表: JDK1.8之前:数组+单向链表
                       JDK1.8之后:数组+单向链表|红黑树(链表的长度超过8):提高查询的速度。

  2.hashMap集合是一个无序的集合,存储元素和取出元素的顺序有可能不一致

当HashMap存储自定义类型键值 为保证key值是唯一的,作为key的元素,必须重写hashCode方法和equals方法。

HashTable

HashMap和HashTable的区别:

Hashtable:底层也是一个哈希表,是一个线程安全的集合,是单线程集合,速度慢
HashMap:底层是一个哈希表,是一个线程不安全的集合,是多线程的集合,速度快

HashMap集合:可以存储null值,null键
Hashtable集合,不能存储null值,null键

LinkedHashMap(java.util.LinkedHashMap<k,v>集合 extends HashMap<k,v>集合)

1.LinkedHashMap集合底层是哈希表+链表(保证迭代的顺序)
 2.LinkedHashMap集合是一个有序的集合,存储元素和取出元素的顺序是一致的

遍历Map集合

1  通过键找值的方式 :

Map集合中的方法:   Set<K> keySet() 返回此映射中包含的键的 Set 视图。

实现步骤:
    1.使用Map集合中的方法keySet(),把Map集合所有的key取出来,存储到一个Set集合中
    2.遍历set集合,获取Map集合中的每一个key
    3.通过Map集合中的方法get(key),通过key找到value

public class TestKeySet{
    public static void main(String[] args) {
        //创建Map集合对象
        Map<String,Integer> map = new HashMap<>();
        map.put("张杰",180);
        map.put("王一博",188);
        map.put("陈顺吉",178);

        //1.使用Map集合中的方法keySet(),把Map集合所有的key取出来,存储到一个Set集合中
        Set<String> set = map.keySet();

        //2.遍历set集合,获取Map集合中的每一个key
        //使用迭代器遍历Set集合
        Iterator<String> it = set.iterator();
        while (it.hasNext()){
            String key = it.next();
            //3.通过Map集合中的方法get(key),通过key找到value
            Integer value = map.get(key);
            System.out.println(key+"="+value);
        }
        System.out.println("-------------------");
        //使用增强for遍历Set集合
        for(String key : set){
            //3.通过Map集合中的方法get(key),通过key找到value
            Integer value = map.get(key);
            System.out.println(key+"="+value);
        }
        System.out.println("-------------------");
        //使用增强for遍历Set集合
        for(String key : map.keySet()){
            //3.通过Map集合中的方法get(key),通过key找到value
            Integer value = map.get(key);
            System.out.println(key+"="+value);
        }
    }
}

2 使用Entry对象遍历

Map集合中的方法:
    Set<Map.Entry<K,V>> entrySet() 返回此映射中包含的映射关系的 Set 视图。

实现步骤:
    1.使用Map集合中的方法entrySet(),把Map集合中多个Entry对象取出来,存储到一个Set集合中
    2.遍历Set集合,获取每一个Entry对象
    3.使用Entry对象中的方法getKey()和getValue()获取键与值

public class TestEntrySet {
    public static void main(String[] args) {
        //创建Map集合对象
        Map<String,Integer> map = new HashMap<>();
        map.put("张杰",180);
        map.put("王一博",188);
        map.put("陈顺吉",178);

        //1.使用Map集合中的方法entrySet(),把Map集合中多个Entry对象取出来,存储到一个Set集合中
        Set<Map.Entry<String, Integer>> set = map.entrySet();

        //2.遍历Set集合,获取每一个Entry对象
        //使用迭代器遍历Set集合
        Iterator<Map.Entry<String, Integer>> it = set.iterator();
        while(it.hasNext()){
            Map.Entry<String, Integer> entry = it.next();
            //3.使用Entry对象中的方法getKey()和getValue()获取键与值
            String key = entry.getKey();
            Integer value = entry.getValue();
            System.out.println(key+"="+value);
        }
        System.out.println("-----------------------");
       // 使用增强for
         for(Map.Entry<String,Integer> entry:set){
            //3.使用Entry对象中的方法getKey()和getValue()获取键与值
            String key = entry.getKey();
            Integer value = entry.getValue();
            System.out.println(key+"="+value);
        }
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值