集合

作者: 知止睿 | 来源:发表于2018-12-13 22:53 被阅读0次


    1.集合(D18)

    1.存储类型

    存储引用数据类型,借助装箱和拆箱

    2.toString

    没有重写toString(),sop(array.get(i))输出的是内存地址

       重写toString()之后,走子类的重写,返回的是person类对象

    sop(对象)会调用toString();

        public String toString(){

    return ("person [ name "+name+", age "+ age + "]");

    }

    3.方法

    clear();    //只删除里面的元素,集合还存在

    contains(Object obj);    //判断对象是否存在于集合中

    toArray();    //集合转数组,返回值为Object类型,因为集合可能为任意类型

    4.Java中三种长度

    数组.length 属性 

    字符串.length() 方法

    集合.size() 方法

    2.iterator

    1.通过一种通用的方法取出集合中的元素

    Iterator it=array.iterator();    //运行结果是iterator的实现类的对象 

    implement::

    ~//调用集合的方法iterator()获取,Iterator接口的实现类的对象

    Colletion<String> coll=new ArrayList<String>();

    Iterator<String> it=coll.iterator();

    while(it.hasnext()){

        sop(it.next());

    }

    ~不写存储的类型

    Colletion coll=new ArrayList ();

    2.for-each

    优点:代码量少,遍历方便,遍历的同时可以调用变量的方法

    缺点:没有索引,无法对容器里的元素做操作

    3.泛型generic

    指定数据类型


    1.List接口(D19)

    1.方法:

    add(int index , Element e);

    E remove(int index)    //移除,并返回被删除的元素

    字符串使用equals进行判断    

    2.ArrayList

    list接口的数组实现,查询快,增删慢,不同步,即线程不安全

    3.LinkedList

    list接口的链表实现,查询慢,增删快,不同步,即线程不安全

    2 .Set接口

    一个不包含重复元素的collecton

    1.HashSet

    借助HashTable(链表数组结合体)实现,存储取出较快,线程不安全

    初始容量15,即数组的长度

    加载因子0.75,即数组存储的数据达到0.75*16=12时,开始扩容,新数组容量32,该过程称为数据的再哈希

    2.存储结构

    判断对象是否重复,在添加时调用对象的自己的hashCode,equals方法,判断是否重复

    3.问题

    两个对象的hashCode相同,equals返回true吗? 不一定

    两个对象equals返回true,hashCode相同吗? 一定

    3.Map

    1.重复的键

    如果存储的是重复的键,将原有的值覆盖

    v put<key,value>    // 返回值一般是null,存储重复键的时候,返回的是被覆盖的元素的值

    v get(k)    // 通过键拿到值

    v remove(k)    //

    2.间接遍历Map

    Map  map=newHashMap();

    map.put("a",1);

    map.put("b",1);

    map.put("c",1);

    Set set=map.keySet();    //HashMap$KeySet

    Iterator it=set.iterator();

    while(it.hasNext()) {

    String key=it.next();

    Integer value=map.get(key);    

    }

    3.Entry关系遍历

    for(Map.Entry entry:map.entrySet()) {

    System.out.println(entry.getValue()+"  "+entry.getKey());

    }

    4.可变参数

    (本质为数组,放在参数列表的最后一位)

    数据类型...变量名

    public int getsum(int...){

        int sum=0

        for(int i:a){

        sum+=i;

    }

        return sum

    }

    4.Collections工具类

    Collections.sort(List list);

    Collections.binarySearch(List list,int i);

    5.集合的嵌套

    eg:

    基础班map<学号,姓名>

    传智播客map<班级名字,基础班map<学号,姓名>>

    集合的遍历

    keyset();

    entrySet();

    //keyset()
    private static void keyset(HashMap<String, HashMap<String, String>> czbk) {

    //czbk方法,keyset()得到键,className

    Set<String> classNameSet=czbk.keySet();

    //迭代set集合

    Iterator<String> classNameIt=classNameSet.iterator();

    while(classNameIt.hasNext()) {

    //classNameIt.next()取出set集合的元素,czbk的键,className

    String classNamekey= classNameIt.next();

    //通过czbk的get()方法,获得值,hashMap

    HashMap<String,String> classMap=czbk.get(classNamekey);

    //classMap.keySet()获取键,学号

    Set<String> studentNum=classMap.keySet();

    Iterator<String> studentIt=studentNum.iterator();

    while(studentIt.hasNext()) {

    //获取学号

    String numkey=studentIt.next();

    //通过学号,获取姓名

    String namevalue=classMap.get(numkey);

    System.out.println(classNamekey+" "+numkey+" "+namevalue);

    }

    }

    相关文章

      网友评论

          本文标题:集合

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