• day14 集合框架--ArrayList容器 linkedlist




    集合框架:Collection

    为什么会出现这么多的容器呢?
    因为每一个容器对数据的存储方式都有不同,
    这个存储方式称之为:数据结构


    CollectionDemo

    创建一个集合容器。使用Collection接口的子类,ArrayList


    /*
    1,add方法的参数类型是Object。以便于接受任意类型对象。
        
    2,集合中存储的都是对象的引用(地址)

    */

    import java.util.*;
    
    class CollectionDemo
    {
        public static void main(String[] args)
        {
            base_method();
            
        }
        
        public static void base_method()
        {
            
            //ArrayList al = new ArrayList();
            
            //1,添加元素
            //al.add("java01");
            //al.add("java02");
            //al.add("java03");
            //al.add("java04");
            //打印原集合
            //sop("scr:"+al);
            //清空
            //al.clear();
            
            //al.remove("java02");
            //获取元素个数,集合长度。
            //sop("size:"+al.size());
            //System.out.println("");
            //判断元素是否存在
            //sop(al.contains("java03"));
            
            //sop(al.isEmpty());//集合是否为空。
            
            sop(al);
            ArrayList al = new ArrayList();
            al.add("java01");
            al.add("java02");
            al.add("java03");
            al.add("java04");
            
            ArrayList all = new ArrayList();
            all.add("java05");
            all.add("java06");
            all.add("java01");
            all.add("java02");
            
            al.retainAll(all);//取交集,al中只会保存于all中相同的元素。
            
            sop("al:"+al);
            sop("all:"+all);
            
            
        }
        public static void sop(Object obj)
        {
            System.out.println(obj);
        }
    }

     Iterator it = al.iterator();//获取迭代器,用于取出集合中的元素。

    什么是迭代器呢?
    其实就是集合的取出元素的方式。

    就把取出方式定义在集合的内部,
    这样取出方式就可以直接访问集合内容的元素。

    那么取出方式就被定义成了内部类。

    而每一个容器的数据结构不同,所以取出的动作细节也不一样。
    但是都有共性内容判断和取出。那么可以将写共性抽取。

    那么这些内部类都符合一个规则。该规则是Iterator
    如何获取集合的取出对象呢

    通过一个对外提供的方法。Iterator();

    import java.util.*;
    
    class ListDemo
    {
        public static void main(String[] args)
        {
            base_method();
            
        }
        
        public static void base_method()
        {
            ArrayList al = new ArrayList();
            
            
            al.add("java01");
            al.add("java02");
            al.add("java03");
            //al.add(1,"java09");
            //sop(al);
            
            //al.remove(2);
            //sop(al);
            //al.set(2,"java007");
            //sop("get:"+al.get(1));
            //sop("index="+al.indexOf("java02"));
            //List sub = al.subList(1,3);
            //sop("sub="+sub);
            ListIterator it = al.listIterator();
            
            while(it.hasNext())
            {
                Object obj = it.next();
                
                if(obj.equals("java02"))
                    it.add("java09");
                
                
            }
            sop(al);
            
        }
        public static void sop(Object obj)
        {
            System.out.println(obj);
        }
    }

    Collection
          |--List;元素是有序的,元素可以重复,因为该集合体系有索引。
            |--ArrayList:底层的数据结构使用的是数组结构。特点:查询速度很快,增删比较慢。线程不同步
                
            |--LinkedList :底层的数据结构使用的是链表数据结构。特点:增删速度快,查询比较慢
            |--Vector  :底层是数组数据结构。线程同步 被ArrayList替代。
        |--Set ;元素是无序的,元素不可以重复。
            |--HashSet
            |--TreeSet
        

    list:
        特有方法:凡是可以操作角标的方法都是该体系特有的方法。

        add(index,element)
        addAll(index,Collection)

        remove(index)

        set(index,element)

        get(index)
        subList(from,to)
        listIterator()
        
        
    List集合特有的迭代器:ListIterator 是Iterator的子接口

    在迭代时,不可以通过集合对象的方法操作集合中的元素。
    因为会发生ConcurrentModificationException异常。
    所以,在迭代器时,只能用迭代器的方法操作元素,可是Iterator方法是有限的
    只能对元素进行判断,取出,删除的操作,
    如果想要其他的操作如添加修改等,就需要使用起子接口,ListIterator。

    该接口这能通过list集合的listiterator方法获取。

    =========================================


    枚举就是Vector 特有的取出方式

    发现枚举和迭代器很像。
    其实枚举和迭代是一样的。

    因为枚举的名称以及方法的名称都过长。
    所以被迭代器取代了
    枚举郁郁而终

     
     import java.util.*;
     
     class VectorDemo
     {
         public static void main(String[] args)
         {
             Vertor v = new Vector();
             
             v.add("java01");
             v.add("java02");
             v.add("java03");
             v.add("java04");
             
             Enumeration en = v.elements();
             
             while(en.hasMoreElements())
             {
                 System.out.println(en.nextElement());
             }
             
             
         }
     } 

    Linklist



    LinkedList:特有方法:
    =====================
    addFirst()
    addLast()
    =====================
    获取元素
    getFirst()
    getLast()
    =====================
    获取元素但是元素被删除,如果集合中没有元素,会返回NoSuchElementException
    removeFirst()
    removeLast()

    在JDK1.6出现了替代方法,如果集合中没有元素,会返回NoSuchElementException

    offerFirst()
    offerLast()

    peekFirst()
    peekLast()
    获取元素但是元素被删除,如果集合中没有元素,会返回null
    pollFirst()
    pollLast();
    获取元素但是元素被删除,如果集合中没有元素,会返回null

     
     import java.util.*;
     
     class LinkedListDemo
     {
         public static void main(String[] args)
         {
             LinkedList v = new LinkedList();
             
             v.addFirst("java01");
             v.addFirst("java02");
             v.addFirst("java03");
             v.add-First("java04");
             
             
             sop(v);
         
         }
         public static void sop(Object obj)
        {
            System.out.println(obj);    
        }
             
     } 

    练习:使用linkedlist模拟一个堆栈或队列数据结构

         
         import java.util.*;
         
         class LinkedListDemo
         {
             public static void main(String[] args)
             {
                duilie dl = new duilie();
                dl.myadd("java01");
                dl.myadd("java02");
                dl.myadd("java03");
                dl.myadd("java04");
             
                System.out.println(dl.myget());
             }
             public static void sop(Object obj)
            {
                System.out.println(obj);    
            }
                 
         } 
        
        class duilie
        {
            private LinkedList link;
            duilie()
            {
                link = new LinkedList();
            }
            public void myadd(Object obj)
            {
                link.addFirst(obj);
            }
            public Object myget()
            {
                return link.removeLast();
            }
            public boolean isNull()
            {
                return link.isEmpty();
            }
        }

     练习:
    去除arraylist集合中的重复元素。

         
         import java.util.*;
         
         class ArrayListTest
         {
             public static void main(String[] args)
             {
                ArrayList dl = new ArrayList();
                dl.add("java01");
                dl.add("java02");
                dl.add("java02");
                dl.add("java04");
             
                sop(dl);
                dl = singleElement(dl);
                
                sop(dl);
             }
             public static void sop(Object obj)
            {
                System.out.println(obj);    
            }
            public static ArrayList singleElement(ArrayList al)
            {
                ArrayList newal = new ArrayList();
                
                Iterator it = al.iterator();
                
                while(it.hasNext())
                {
                    Object obj = it.next();
                    if(!newal.contains(obj))
                        newal.add(obj);
                }
                return newal;
            }
                 
         } 
        
        

    练习:
    将自定义对象作为元素存到ArrayList集合中,并去除相同元素。
    比如 :存人

    同姓名同年龄是为同一个人。为同一个人。

    list集合判断元素是否相同,调用contains函数,这函数依据的元素的equals方法。

         
         import java.util.*;
         
          
         class person
         {
             private  String name ;
             private  int age;
             
             person(String name,int age)
             {
                 this.name=name;
                 this.age=age;
             }
             
             
             public String getname()
             {
                 return name;
             }
             public int getage()
             {
                 return age;
             }
             public boolean equals(Object obj)
             {
                 if(!(obj instanceof person))
                     return false;
                 person p  =(person)obj;
                 
                 return this.name.equals(p.name)&&this.age == p.age;
             }
             
         }
        
        
         class ArrayListTest
         {
             public static void main(String[] args)
             {
                ArrayList dl = new ArrayList();
                dl.add(new person("lisi01",30));
                dl.add(new person("lisi02",32));
                dl.add(new person("lisi02",32));
                dl.add(new person("lisi03",33));
                dl.add(new person("lisi04",35));
                dl.add(new person("lisi04",35));
                
                dl=singleElement(dl);
                
                Iterator it = dl.iterator();
                
                while(it.hasNext())
                {
                    person p = (person) it.next();//Object obj = it.next(); person p = (person) obj;
                    sop(p.getname()+":...:"+p.getage());
                }
             }
             public static void sop(Object obj)
            {
                System.out.println(obj);    
            }
            public static ArrayList singleElement(ArrayList al)
            {
                ArrayList newal = new ArrayList();
                
                Iterator it = al.iterator();
                
                while(it.hasNext())
                {
                    Object obj = it.next();
                    if(!newal.contains(obj))
                        newal.add(obj);
                }
                return newal;
            }
                 
         } 
        
        

     
    |--Set ;元素是无序的(存入和取出的顺序不一定一致),元素不可以重复。
            |--HashSet:底层数据结构是哈希表
                HashSet是如何保证元素唯一性呢
                是通过元素的两个方法,hashCode和equals来完成的
                如果元素的HashCode值相同,才会判断equals是否为true
                如果元素的hashcode值不同,不会调用equals
                
                注意,对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashcode和equals方法
                
            |--TreeSet
            
    Set集合的功能和Collection是一致的。

    往hashset集合中存入自定义对象
    姓名和年龄相同为同一个,重复元素。
          set练习:

    import java.util.*;
    
    
    
         class person
         {
             private  String name ;
             private  int age;
             
             person(String name,int age)
             {
                 this.name=name;
                 this.age=age;
             }
             public int hashCode()
            {
                return 30;
            }
             
             public String getname()
             {
                 return name;
             }
             public int getage()
             {
                 return age;
             }
             public boolean equals(Object obj)
             {
                 if(!(obj instanceof person))
                     return false;
                 person p  =(person)obj;
                 
                 return this.name.equals(p.name)&&this.age == p.age;
             }
             
         }            
    class HashSetDemo
    {
        
        public static void main(String[] args)
        {
            HashSet hs = new HashSet();
            hs.add(new person("java01",11));
            hs.add(new person("java02",12));
            hs.add(new person("java02",12));
            hs.add(new person("java03",13));
            hs.add(new person("java04",14));
            
            Iterator it = hs.iterator();
            
            while(it.hasNext())
            {
                person p = (person)it.next();
                sop(p.getname()+"::"+p.getage());
            }
        }
        
        public static void sop(Object obj)
        {
            System.out.println(obj);
        }
    }
  • 相关阅读:
    MHA自动切换流程
    手写源码之 简单实现on emit off
    手写源码 -- bind,call,aplly
    多维数组转化为一维数组
    electron+vue中使用nodeJs的fs模块以及上传文件
    制作海报
    vue中引入播放器(百度播放器和腾讯云播放器)
    webpack配置
    webpack
    css样式
  • 原文地址:https://www.cnblogs.com/WDKER/p/5641466.html
Copyright © 2020-2023  润新知