美文网首页
Collection

Collection

作者: SheBang_ | 来源:发表于2016-07-21 23:21 被阅读31次
    COLLECTION.png
    容器类型 容器中数据
    Set 数据对象没有顺序且不可重复
    List 数据对象有顺序且可以重复
    Map key-value映射对的方法
    package mashibing.java;
    
    import java.util.Collection;
    import java.util.HashSet;
    
    public class BasicContainer {
        public static void main(String[] args){
            Collection<Object> c = new HashSet<>();
            //父类引用指向子类对象
            c.add("Hello");
            c.add(new Name("f1","l1"));
            c.add(new Integer(100));
    
            c.remove("Hello");//String重写了equals方法
            c.remove(new Integer(100));//integer重写了equals方法,所以两者对象相等
            //remove和add方法返回的都是布尔类型
            System.out.println(c.remove(new Name("f1","l1")));//name没有重写equals方法所以这是两个对象
            System.out.println(c);
            
        }
    }
    
    class Name{
        private String firstName,lastName;
        public Name(String firstName,String lastName){
            this.firstName = firstName;
            this.lastName = lastName;
        }
        public String getFirstName(){
            return firstName;
        }
        public String getLastName(){
            return lastName;
        }
        public String toString(){
            return firstName + "" + lastName;
        }
        
        public boolean equals(Object obj){
            if(obj instanceof Name){
                //如果obj是Name的一个子类,那么把obj强制转化成Name类
                Name name = (Name)obj;
                return (firstName.equals(name.firstName))
                        &&(lastName.equals(name.lastName));
            }
            return super.equals(obj);
            //如果它都不是Name类,那么交给object的equals来处理,也就是==
            
        }
        /*
         * 容器类对象在调用remove,contains等方法的时候,需要比较对象是否相等,这会涉及到
         * 对象类型的equals方法和hashCode方法,对于自定义的类型,需要重写equals方法和
            hashCode方法以实现自定义的对象相等规则,因为原本的Object的对象的equals方法是==,
            也就是需要两个引用的是同一个对象才能equals
            注意:相等的对象应该具有相等的hash codes,在map调用的时候,会使用hashcode方法
         */
        
        public int hashCode(){
            return firstName.hashCode();
        }
    }
    

    介绍下Iterator接口:

    package mashibing.java;
    
    import java.util.Collection;
    import java.util.HashSet;
    import java.util.Iterator;
    
    public class Test {
     public static void main(String[] args){
      Collection<Object> c = new HashSet<>();
      //set是没有顺序的,且不可以重复的
      c.add(new Name("f1","l1"));
      c.add(new Name("f2","l2"));
      c.add(new Name("f3","l3"));
      Iterator<Object> i = c.iterator();
      /*
       * Collection接口有一个方法叫做iterator,这个方法返回的是一个实现了了
       * Iterator接口的对象,Iterator有三个方法,hasNext,查看是否有下一个对象
       * next方法,返回下一个对象还有一个remove方法,该remove方法是在迭代中删除元素唯一
       * 安全的方法
       */
    
      while(i.hasNext()){
       Name n = (Name)i.next();
       //这里知道返回的是一个Name对象,那么就就返回的强制转换成Name
       System.out.print(n.getFirstName()+"  ");
      }
     }
    }
    

    Interator循环,三个方法的使用

    package mashibing.java;
    
    import java.util.Collection;
    import java.util.HashSet;
    import java.util.Iterator;
    
    public class Remove {
     public static void main(String[] args){
      Collection<Object> c = new HashSet<Object>();
      c.add(new Name("fff1","llll"));
      c.add(new Name("f2","l2"));
      c.add(new Name("ffff3","lll3"));
      for(Iterator<Object> i = c.iterator();i.hasNext();){
       //这里for循环只有两个条件,一个是产生这么一个Iterator对象,
    //   另外一个是还有下一个值
       Name name = (Name)i.next();
       if(name.getFirstName().length()<3){
        i.remove();
        /*
         * 这里使用了Iterator接口的remove方法,因为Iterator循环内部中
         * 在操作数据的时候讲数据锁定了
         * 如果我们换成c.remove(name)就会产生例外
         */
       }
      }
      System.out.println(c);
     }
    }
    

    Set

    增强的for循环

    package mashibing.java;
    
    import java.util.ArrayList;
    import java.util.Collection;
    //增强的for循环
    public class EnhanceFor {
     public static void main(String[] args){
      int[] arr = {1,2,3,4,5};
      for (int i : arr) {
       System.out.println(i);
      }
      //缺点是只能看不能按照下标来修改,好处就是语法比较简单
      Collection<String> c = new ArrayList<String>();
      c.add(new String("aaa"));
      c.add(new String("bbb"));
      c.add(new String("ccc"));
      for(Object o:c){
       System.out.println(o);
      }
     }
     
    }
    

    Set是不能重复的但是没有顺序的集合

    package mashibing.java;
    
    import java.util.HashSet;
    import java.util.Set;
    
    public class Testset {
        public  static void main(String[] args){
            Set<Object> s = new HashSet<Object>();
            s.add("hello");
            s.add("world");
            s.add(new Name("f1","f2"));
            s.add(new Integer(100));
            s.add(new Name("f1","f2"));
            s.add("hello");
            System.out.println(s);
            /*
             * 如果两个元素equals,那么add是添加不进去的。所以这里Set的结果是
             * [hello, 100, f1f2, world]顺序无所谓,因为Set本身就没有顺序
             */
        
        }
    }
    
    

    Set接口是Collection的子接口,Set接口没有提供额外的方法,但是Set容器中得元素是没有顺序的,而且是不可以重复,Set容器类有HashSet、TreeSet等。

    package mashibing.java;
    
    import java.util.HashSet;
    import java.util.Set;
    
    public class Testset2 {
        public static void main(String[] args){
            Set<Object> s1 = new HashSet<Object>();
            Set<Object> s2 = new HashSet<Object>();
            s1.add("a");
            s1.add("b");
            s1.add("c");
            
            s2.add("d");
            s2.add("a");
            s2.add("b");
            
            Set<Object> sn = new HashSet<Object>(s1);
            sn.retainAll(s2);//求交集
            Set<Object> su = new HashSet<Object>(s1);
            su.addAll(s2);
            /*
             *  把s2添加到啊su中,但是重复的是添加不进来的因为Set中只能有不重复的
             * 所以su打印出来的结果是[d, b, c, a]
             */
            System.out.println(sn);
            System.out.println(su);
            
        }
    }
    

    相关文章

      网友评论

          本文标题:Collection

          本文链接:https://www.haomeiwen.com/subject/iktijttx.html