java–集合

java–集合

Collection:  add(Object obj)  addAll(Collection c) size() clrear() isEmpty()
        remove(Object obj) removeAll(Collection c) retainAll(Collection c)
        contains(Object obj) containsAll(Collection c) hashCode()
        iterator(), toArray()
    

    –>List:有序,可以重复存储元素
        特有的: add(int index, Object obj) remove(int index)
               Object set(int index, Object obj)
               Object get(int index)   int indexOf(Object obj)
               int lastIndexOf(Object obj)   List subList(int from, int to)
        
        –>ArrayList:内部是一个数组结构,不同步,代替了Vector,查询快
        –>LinkedList:内部数据结构是一个链表, 不同步,增删快
        –>Vector:内部数据结构也是数组,同步的。增删查都慢
    
    
    –>Set:无序,元素唯一
        Set接口与Collection接口中的方法一致
        
        –>HashSet:内部数据结构是哈希表,不同步。
                怎么保证存储的元素唯一呢?
                通过对象的hashCode和equals方法来确定的
                如果对象的hashCode不同,就不用再判断equals方法了,直接存储到集合中
                如果对象的hashCode相同,就需要根据equals方法来进行判断
                            如果结果为true,视为相同,不再进行存储
                            如果为false,视为不同,就进行存储(不建议)
                            
                注意:如果元素存储到hashSet中,必须要覆盖hashCode和equals方法
                    尽量这两个方法保持一致
                
            –>LinkedHashSet:是其子类,当我们遍历集合的时候,是按照我们添加顺序进行的
                    频繁的遍历,但是增删比较少,可以选择这种集合
        –>TreeSet:可以对元素进行排序,是不同的
                判断元素唯一性的方式:就是根据比较方法返回的结构,0(相同), 不存储
                排序的方式?
                1.元素自身具有比较的功能,实现Comparable接口,重写compareTo方法
                2.元素自身不具有比较功能,没有实现Comparable接口,这个时候怎么办呢?
                    定义一个类,实现Comparator接口,重写compare方法
                    把这个类创建的对象作为参数,通过构造函数传递给TreSet集合

Map: 一次添加一对元素,    Collectio一次添加一次元素
    Map也成为双列集合,    Collection也成为单列集合
    Map中key必须唯一
    
    put(Object key, Object value)  remove(Object key) clear(), size()
    isEmpty()  Object get(Object key)   boolean containsKey(Object key)
    boolean containsValue(Object value)
    
    循环方式?
    1. keySet  –>得到key的集合,循环得到每一个key,通过get(key),获取value
    
    2.entrySet –>得到key和value整体的一个Map.Entry集合,循环得到每一个Map.Entry对象
                通过调用getKey()和getValue(),获取key和value
    
    
    –>HashMap:内部数据结构是哈希表,不同步。允许null作为key或者value
        
        –>LinkedHashMap:是其子类,可以按照添加进map的顺序进行遍历
        
    –>TreeMap:内部数据结构是二叉树,是不同步的。可以对key进行排序
    
    –>HashTable:很少用
        –>Properties:根据IO来一起使用

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114805.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 笛卡尔积算法「建议收藏」

    笛卡尔积算法「建议收藏」/***生成笛卡尔积*@paramdimvalue*@paramresult*@paramlayer*@paramcurList*/privatestaticvoiddescartes(List

    2022年7月27日
    15
  • 使用stress进行压力测试

    使用stress进行压力测试stress介绍stress是一款压力测试工具,可以用它来对系统CPU,内存,以及磁盘IO生成负载。安装stressapt-getinstallstress使用stress直接运行stress就会列出关于stress的简单说明root@myy/root$stress-?`stress’imposescertaintypesofcomput…

    2025年8月1日
    4
  • getchar的使用方法_c语言strlen函数用法

    getchar的使用方法_c语言strlen函数用法getchar只能解决一个字符例1:#define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>intmain(){intch=getchar();//printf(“%c\n”,ch);putchar(ch);//输出一个字符return0;}例2:#define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>intmain()…

    2022年10月10日
    3
  • 基于JavaWeb网上商城(以卖书为主)

    基于JavaWeb网上商城(以卖书为主)本文章是JavaWeb课程的课程设计1.项目概况1.1课题背景、目的及意义1.1.1课题背景随着互联网的普及和电子商务的兴起,网上图书销售是互联网电子商务在图书销售行业中的必然结果,这种新型的图书销售形式越来越受人们的欢迎,正在以不可阻挡的气势替代着传统的图书销售模式。与其传统销售模式相比拥有许多优势,一是降低了销售成本,二是利用互联网作为交易平台,是的交易活动不受时间和空间的限制,…

    2022年7月8日
    25
  • 关于读书的名言名句_contentdescription

    关于读书的名言名句_contentdescription没有永恒的技术只有变态的需求,没有好说的客户只有无奈的开发者,如果iframe的出现是一个错误的话,iframe里边在来一个iframe那是错上加错,神话没有在远古的尘嚣中消失,却在怀具的今天不断上演。生活永远是一个大染缸,一块白布下去,黑布出来,一块黑布下去,一块七色布出来。contentWindow兼容各个浏览器,可取得子窗口的window对象。contentDocume…

    2022年8月30日
    6
  • 电商平台后端_什么电商运营

    电商平台后端_什么电商运营http://www.imooc.com/view/148?from=cnblogs

    2022年8月3日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号