zoukankan      html  css  js  c++  java
  • J2SE 容器

    知识点:Collection接口、Iterator接口、增强的for循环、Set接口、List接口和Comparable接口、Collection类、Map接口、自动打包/解包、泛型

    容器:API文档位于 java.util 包内

    容器有这几种:数组、Set、Lish、Map

    1、Collection 接口

    • 定义了一组存取对象的方法,存储方式有Set 和 List
      • Set 中的数据对象没有顺序且不可重复
      • List 中的对象有顺序且可以重复
    • Map 接口:定义了存储“键(key)--- 值(value)”映射对的方法

     

    • Collection 接口所定义的方法:

     

    • 容器类对象在调用remove、contains等方法时,需要比较两个对象是否equals,这会涉及到对象类型的equals方法和hashCode方法;
    • 对于自定义的类型,需要重写equals和hashCode方法,以实现自定义的对象相等规则
    • 当对象用在Map接口里头作为键(key)使用的时候,会使用hashCode方法(hashCode特别适合用作索引)
    • 重写equals方法,必须重写hashCode方法
    • 两个对象如果互相的equals,则他们两个必须具备相同的hashCode
    //remove某个对象的时候,会从容器中挨个将对象取出来与这个对象作比较,如果有对象和这个对象equals,则remove成功
    import java.util.*;
    
    public class BasicContainer{
        public static void main(String args[]){
            Collection c = new HashSet();  //用哈希表实现的容器c(父类引用指向子类对象)
            
            c.add("hello");
            c.remove("hello");//remove成功
            
            //Integer也重写了equals方法,所以只要值一样,这两个对象就就equals
            c.add(new Integer(100));        
            c.remove(new Integer(100));//remove成功
            
            c.add(new Name("f1","l1"));
            Syetem.out.println(c.remove(new Name("f1","l1")));//返回“false”
            //这两个Name对象并不equals,这个Name对象并没有重写equals的情况下,他们两个equals只有一个条件:指向同一对象
            
            System.out.println(c);//
        }
    }
    
    class Name{
        private String firstName,lastName;
        public Name(String firstName,String lastName){
            this.firstName = firstName;
            this.lastName = lastName;
        }
        
        //重写Name对象的equals和hashCode方法如下:
        public boolean equals(Object obj){
            if (obj instanceof Name){  //如果obj是一个Name对象
                Name name = (Name) obj;  //将obj强制转换成一个Name对象
                return (firstName.equals(name.firstName)) && (lastName.equals(name.lastName));//只有传进来的firstname和lastname都相等时才返回true
            }
            return super.equals(obj);//如果obj不是一个Name对象,交给父类处理,Name的父类为object。object的equals方法:比较当前对象和传进来的对象是不是同一对象
        }
        public int hashCode(){
            return firstName.hashCode();
        }
    }

    2、Iterator接口

    • 所有实现了Collection接口的容器类都有一个iterator方法,用以返回一个实现了Iterator接口的对象
    • Iterator对象成为迭代器,用以方便的实现对容器内元素的遍历操作
    • Iterator接口就是一个统一用来遍历Collection元素的方法(无论对象是装在数组、链表、哈希表里,但是对于Iterator来说,都是一样的。Iterator就像一个游标,指在第一个元素的左边)

     

    3、Set接口

    Set接口是Collection的子接口,实现Set接口的容器类中的元素是没有顺序且不可以重复的,

    Set类容器有HashSet和TreeSet

    4、List 接口

    5、Map 接口

     实现Map接口的类用来存储 “ 键---值 ” 对

    Map接口的实现类有HashMap 和 TreeMap等

    Map类中存储的键---值对通过键来标识,所以键值不能重复(互相不能equals,HashCode不能重复)

    5、 Comparable接口

    6、泛型

    在定义集合的时候,同时定义集合中对象的类型

     练习:

    import.java.util.*;
    public class TestArgsWords{
        public static void main(args[]){
            Map m = new HashMap();
            for(int i = 0;i < args.length();i++){  //args是一个数组,循环args
            //m.get(args[i])  以args[i]为key的那个value,如果没有则返回null
                int number = (Integer) m.get(args[i]) == null ? 0 : (Integer) a.get(args[i]);//判断是否为空,如果为null就等于0,如果不为空就等于他本身
                m.put(args[i],number==0 ? 1 : number + 1);//如果number为0(即m.get(args[i]) == null),则number=0;如果number为1,则为number加1
            }
            System.out.println(m.size());
            Syetem.out.println(m);
        }
    }
    //泛型:(不需要强制转换)
    import.java.util.*;
    public class TestArgsWords{
        public static void main(args[]){
            Map<String,Integer> m = new HashMap<String,Integer();
            for(int i = 0;i < args.length();i++){  //args是一个数组,循环args
            //m.get(args[i])  以args[i]为key的那个value,如果没有则返回null
                int number = m.get(args[i]) == null ? 0 : a.get(args[i]);//判断是否为空,如果为null就等于0,如果不为空就等于他本身
                m.put(args[i],number==0 ? 1 : number + 1);//如果number为0(即m.get(args[i]) == null),则number=0;如果number为1,则为number加1
            }
            System.out.println(m.size());
            Syetem.out.println(m);
        }
    }

  • 相关阅读:
    『中级篇』docker导学(一)
    计算机或许已经烂大街了,女生学计算机没出路吗?
    「初级篇」跟我一起学docker(17)--多节点mesos集群
    「初级篇」跟我一起学docker(18)--持续集成(初级终结篇)
    「初级篇」跟我一起学docker(16)--单节点mesos集群
    QT socket 多线程管理
    mysql数据库引擎 MyISAM和 InnoDB区别
    sql 删除表格delete drop truncate 区别(转)
    按层次遍历二叉树
    php基础排序算法 冒泡排序 选择排序 插入排序 归并排序 快速排序
  • 原文地址:https://www.cnblogs.com/luwanying/p/9737697.html
Copyright © 2011-2022 走看看