zoukankan      html  css  js  c++  java
  • JAVA笔记整理(九),JAVA中的集合

             在工作中,我们经常需要将多个对象集中存放,可以使用数组,但是数组的长度一旦固定之后是不可变的,为了保存数量确定的数据,我们可以使用JAVA中的集合。

             在我看来,JAVA中的集合可以看作是一个特殊的数据库,可以针对这个数据库进行数据的增删查改,可以查看数据库的大小,查看数据库是否为空等等。

             JAVA中的集合是由Collection和Map两个接口派生出来的,正因为是两个接口,所以只能通过其子类来将其实例化,下图为常用集合:

      

      

      Collection是List、Queue和Set接口的父接口,Map是HashMap的父接口。

               正因为是接口,所以实际使用是需要通过其子类将其实例化。

      Collection可以看作是传统意义上的数据库,提供一系列针对数据库的增删查改判断操作

        List  

    public class ListDemo01 {
        public static void main(String[] args) {
            List list = new ArrayList();
    
            // 使用add()向List中添加元素,可见List是可重复的
            list.add("A");
            list.add("B");
            list.add("A");
    
            // 通过循环遍历集合内容
            for (int i = 0; i < list.size(); i++) { // 使用size()方法获得list长度
                System.out.println("第" + (i + 1) + "个元素是: " + list.get(i)); // 使用get(x)来获得list中第x位置的元素
            }
    
            // 使用remove(x)来移除list中第x位的元素
            list.remove(1);
    
            // 通过循环遍历集合内容
            for (int i = 0; i < list.size(); i++) { // 使用size()方法获得list长度
                System.out.println("移除之后,第" + (i + 1) + "个元素是: " + list.get(i)); // 使用get(x)来获得list中第x位置的元素
            }
    
            // 使用isEmpty()来查看集合是否为空,如果返回true则为空,false则不为空
            if (list.isEmpty()) {
                System.out.println("这个集合是空的");
            } else {
                System.out.println("这个集合不是空的");
            }
    
            // 使用addAll将另一个集合添加到集合中
            List list2 = new ArrayList();
            list2.add(123);
            list2.add("D");
            list2.add(123);
    
            list.addAll(list2);
    
            for (int i = 0; i < list.size(); i++) { // 使用size()方法获得list长度
                System.out
                        .println("移除之后,又添加后,第" + (i + 1) + "个元素是: " + list.get(i)); // 使用get(x)来获得list中第x位置的元素
            }
    
            // 使用contains(x)方法来判断集合中是否存在x元素
            if (list.contains("Z")) {
                System.out.println("集合中存在这个元素");
            } else {
                System.out.println("集合中不存在这个元素");
            }
    
            // 使用containsAll(x)方法来判断集合中是否包含某个集合
            List list3 = new ArrayList();
            list3.add("A");
            list3.add("B");
    
            if (list.containsAll(list3)) {
                System.out.println("list中包含list3");
            } else {
                System.out.println("list中不包含list3");
            }
    
            // 使用indexOf(x)来获取x元素在集合中的位置,如果存在该元素,则返回该元素首次出现的位置,如果不存在,则返回-1
            System.out.println("123在list2中出现的位置为: " + list2.indexOf(123));
            System.out.println("123在list2中出现的位置为: " + list2.indexOf(456));
            
            // 使用indexOf(x)来获取最后一个x元素在集合中的位置,如果存在该元素,则返回该元素最后出现的位置,如果不存在,则返回-1
            System.out.println("123在list2中最后一次出现的位置为: " + list2.lastIndexOf(123));
            System.out.println("123在list2中最后一次出现的位置为: " + list2.lastIndexOf(456));
            
            //使用set(x,y)来讲list中第x个元素替换为y
            list2.set(2, 456);
            for (int i = 0; i < list2.size(); i++) {
                System.out.println("替换之后,list的第" + (i+1) + "个元素为: " + list2.get(i));
            }
        
         System.out.println(list2);
    } }

       

             所有的Collection的实现类都重写了toString()方法,并且ArrayList是以“动态数组”的形式来存储数据的,当使用System.out.println()来直接输出List的话,会输出[xx,yy,zz]的形式

    set

             HashSet是Set的实现类,它就好像一个箱子,我们可以往这个箱子里放若干个对象,但是我们却无法获取到箱子里面对象的顺序,也不能放相同的对象

             HashSet和ArrayList提供的方法基本相同,只是HashSet中不允许添加重复的对象,如果使用add()添加重复对象,则会返回false,并且新添加的元素不会被添加。

             当向一个HashSet添加一个元素的时候,HashSet会调用该对的hashCode()方法来获取到这个对象的hashCode值,然后集合中存在相同hashCode的对象,则添加不成功。

    public class SetDemo02 {
        public static void main(String[] args) {
            Set set = new HashSet();
    
            //通过add(x)方法来讲x元素添加到set中
            set.add("A");
            set.add(1234);
            set.add(1234);
            
            //使用set的iterator()方法获取到set的迭代期,再通过迭代期的next()方法获取到set中的值
            //通过输出结果可以看到上面添加的1234其实只添加成功一个
            Iterator iterator = set.iterator();
            while (iterator.hasNext()) {
                System.out.println(iterator.next());            
            }
            
            Set set2 = new HashSet();
            set2.add("B");
            set2.add("C");
            set2.add("D");
            
            //通过addAll()方法来将一个set集合添加到另一个中
            set.addAll(set2);
            
            iterator = set.iterator();
            System.out.println("添加进一个集合之后,集合中的元素有");
            while (iterator.hasNext()) {
                System.out.println(iterator.next());
            }
            
            //通过contains()方法来判断集合中是否包含某个元素
            if (set.contains("A")) {
                System.out.println("这个集合中包含A元素");
            }else {
                System.out.println("这个集合中不包含A元素");
            }
            
            //使用remove(x)来移除集合中的x元素,如果存在并移除,则返回true,否则返回false
            if (set.remove("A")) {
                System.out.println("集合中存在A元素,并且已经移除");
            }else {
                System.out.println("集合中不存在A元素");
            }
        }
    }

    Map

             JAVA提供了一种以<键,值>形式存储的集合---Map,你可以通过“键”查找“值”。一个 Map 中不能包含相同的 key ,每个 key 只能映射一个 value 。

             Map是一个接口,他提供了HashMap, HashtableLinkedHashMap等子类,实际中常用HashMap。

             Map 接口提供三种collection 视图,允许以键集、值集或键-值映射关系集的形式查看某个映射的内容。

    public class MapDemo01 {
        public static void main(String[] args) {
            Map<String, String> map = new HashMap<String, String>();
            //使用put(x,y)来添加键值对
            map.put("key1", "value1");
            map.put("key2", "value2");
            map.put("key3", "value3");
            map.put("key4", "value4");
            map.put("key5", "value5");
            map.put("key6", "value6");
    
            //通过get(x)来获取key为x的值
            String str = map.get("key1");
            System.out.println(str);
    
            //使用containsKey(x)来判断是否存在key为x的键值对
            if (map.containsKey("key3")) {
                System.out.println("key值为key3的集合存在");
            } else {
                System.out.println("key值为key3的集合不存在");
            }
    
            //使用containsValue(x)来判断是否存在Value为x的键值对
            if (map.containsValue("key3")) {
                System.out.println("value值为key3的集合存在");
            } else {
                System.out.println("value值为key3的集合不存在");
            }
    
            //使用keySet()来获取map中所有键,返回一个Set集合
            Set<String> set = map.keySet();
            Iterator<String> iterator = set.iterator();
            while (iterator.hasNext()) {
                String s = iterator.next();
                System.out.println("key:" + s + "----value:" + map.get(s));
            }
            
            //使用values()来获取map中所有值,返回一个Collection
            Collection<String> c = map.values();
            Iterator iterator2 = c.iterator();
            while (iterator2.hasNext()) {
                System.out.println(iterator2.next());
            }
            
            //使用remove(x)来移除key为x的键值对
            map.remove("key3");
            System.out.println("移除之后,map中剩余的键值对");
            Collection<String> c2 = map.values();
            Iterator iterator3 = c2.iterator();
            while (iterator3.hasNext()) {
                System.out.println(iterator3.next());
            }
            
        }
    }

      

      

  • 相关阅读:
    朱刘算法---有向图的最小生成树
    527D Clique Problem 判断一维线段没有两辆相交的最大线段数量
    Tex中的引号
    DAY 96 flask05
    DAY 95 flask04
    DAY 94 flask03
    DAY 93 flask02
    DAY 92 flask01
    DAY 91 爬虫05
    DAY 90 爬虫04
  • 原文地址:https://www.cnblogs.com/xs104/p/4598950.html
Copyright © 2011-2022 走看看