Set, List, Map

Set和List,Map都是集合,Set和List都是继承于Collection接口,而Map不是。

1.Map(映射)

  Map是以key,Value的形式存储数据的映射集合,在取出数据时也是以key去获取value的值。

  .HashMap:一个典型的继承Map的类,内部是基于散列表来存取数据,大大的提高了数据的访问速度。key的值是不能重复的,但是value值是可以重复。

  .LinkedHashMap:类似于HashMap,只是迭代遍历时是按照插入的顺序排列的。

  .TreeMap:以树的形式存储数据,迭代遍历的值是经过排序的。

  主要方法:

    void put(Object key, Object value);  像map集合插入元素

    Object get(Object key);  根据key的值取得所映射的元素

    Object remove(Object key);  删除key所映射的元素,并返回该元素

    void putAll(Map m);  将符合标准的map插入到此map中

    void clear();  清空整个集合

    Set keySet();  获取所有的key值

    Collection values();  获取所有的value值

    因为Map的key是不可重复的,所以获取的key值存入Set集合,而value是可重复的,所以存入Collection

2.Set(集合)

  Set集合是一个不可重复,无序的集合。与Colletion一模一样

  .HashSet:内部以HashMap来存储数据的HashSet的值为HashMap的key值,HashMap的value是一个Object的类

  .TreeSet:TreeSet类实现了SortedSet接口,对集合中的对象进行排序

  主要的方法:

    void add(Object obj);   向集合添加一个元素

    boolean remove(Object obj);   删除集合中的指定元素, 成功返回true

    void clear();  清空整个集合

    Object[] toArray();  将集合转换为一个数组

    boolean contains(Object obj)  集合是否存在obj元素

   遍历Set集合需要使用迭代器Iterator

       Iterator it = set.iterator();

     while (it.hasNext()) { // 是否存在下一个元素

      it.next(); // 存在,取得下一个元素

     }

3.List(列表)

  List继承于Collection,但是相比较于Set,List在继承Collection的同时,添加了跟多的方法,且List集合是线性存储

  .ArrayList:内部以Array的形式实现,优点:查找访问速度快

  .LinkedList:内部以链表的形式实现,优点:插入,删除等操作速度快

  List集合可以使用新循环和迭代器遍历集合:

    for:

    for (Object obj : list) {

      System.out.println(obj);

    }

    Iterator:

    Iterator it = list.iterator();

    while(it.hasNext()) {

      Systemo.out.println(it.next());

    }

  主要方法:

    void add(Object obj);   添加元素

    void add(int index, Object obj);  插入元素到指定位置

    void get(int index);  取得指定位置元素

    void remove(int index);  删除指定位置元素

    int indexOf(Object obj);  制定元素的地址

    void toArray();  将集合转换为数组

    int Size();  集合的长度

    

java的Set, List, Map简单介绍的更多相关文章

  1. Java EE设计模式(主要简单介绍工厂模式,适配器模式和模板方法模式)

    Java EE设计模式分为三种类型,共23种: 创建型模式:单例模式.抽象工厂模式.建造者模式.工厂模式.原型模式. 结构型模式:适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代理模式 ...

  2. Java并发:ThreadLocal的简单介绍

    作者:汤圆 个人博客:javalover.cc 前言 前面在线程的安全性中介绍过全局变量(成员变量)和局部变量(方法或代码块内的变量),前者在多线程中是不安全的,需要加锁等机制来确保安全,后者是线程安 ...

  3. Java静态检测工具/Java代码规范和质量检查简单介绍(转)

    静态检查: 静态测试包括代码检查.静态结构分析.代码质量度量等.它可以由人工进行,充分发挥人的逻辑思维优势,也可以借助软件工具自动进行.代码检查代码检查包括代码走查.桌面检查.代码审查等,主要检查代码 ...

  4. 【细说Java】方法重载的简单介绍

    1. 什么是重载 方法名称相同,但它们的参数类型或个数不同,这样,方法在被调用时编译器就可以根据参数的类型与个数的不同加以区分,这就是方法的重载. 既然可以通过参数类型或参数个数来作为重载条件,那返回 ...

  5. Java中基本类型和引用类型(简单介绍)

    8种基本类型  一.4种整型 byte      1字节           -128——127     short     2 字节         -32,768 —— 32,767     in ...

  6. java中的泛型,简单介绍。 修饰方法的用法

    一.<R>  ( R  r ) 默认object  可以存所有类型.   R 这个是随便定义的大写字母,前后要保持一致性! package com.aaa.test; /* * 演示 泛型 ...

  7. Java -- POI -- 入门使用以及简单介绍

    1.创建工作簿 (WORKBOOK) HSSFWorkbook wb = new HSSFWorkbook(); FileOutputStream fileOut = new FileOutputSt ...

  8. Java之字节码(3) - 简单介绍

    转载来自 首先了解一下理论知识: 字节码: Class文件是8位字节流,按字节对齐.之所以称为字节码,是因为每条指令都只占据一个字节,所有的操作码和操作数都是按字节对齐的.如:0×03表示iconst ...

  9. Java中的wait方法 简单介绍。

    一 wait方法怎么用? package com.aaa.threaddemo; /* * 多线程中的wait方法? public final void wait() throws Interrupt ...

随机推荐

  1. UltimateRecyclerView的用法具体解释

    近期在用非常多第三方库的时候,发现有一些附带的demo写的不是非常全面或者样例的代码太多,凝视太少,要想使用还要去看下源代码什么的(.. .用第三方开源库不就是想节省时间嘛).所以决定每周两到三篇.写 ...

  2. python发送post请求上传文件,无法解析上传的文件

    前言 近日,在做接口测试时遇到一个奇葩的问题. 使用post请求直接通过接口上传文件,无法识别文件. 遇到的问题 以下是抓包得到的信息: 以上请求是通过Postman直接发送请求的. 在这里可以看到消 ...

  3. 前端基础——CSS盒子模型

    如今很多网页都是由很多个"盒子"拼接.嵌套而成,所以多少接触过网页设计的朋友一定都对CSS盒子模型有所了解. 为了更好的说明,先举个通俗的样例:在一个仓库中放了10个纸箱,每一个纸 ...

  4. iOS Dev (26) 初步了解下UIColor的最常用知识

    作者:CSDN 大锐哥 地址:http://blog.csdn.net/prevention - 内置的颜色有啥? // Some convenience methods to create colo ...

  5. Struts2中数据封装机制

    Struts2当中数据封装的三种机制:属性驱动.标签驱动.模型驱动.下面来一一介绍. 一.属性驱动 1.需要提供对应属性的set方法进行数据的封装. 2.表单的哪些属性需要封装数据,那么在对应的Act ...

  6. 理解c/c++指针和引用

    1 指针的指针 比如int* a,那么a是指向一个int型的对象的.也就是说,*前面的类型是该指针指向的对象的类型. 同理int** a的话,a指向一个int*型的对象,也就是说,它指向的对象也是一个 ...

  7. 在MFC中使用大漠插件

    打开Class Wizard,Add Class...->MFC Class From TypeLib... File->Location->>> Finish-> ...

  8. hdu1427 速算24点

    </pre><pre> //#pragma comment(linker, "/STACK:102400000,102400000") //HEAD #in ...

  9. DNS常见攻击与防范

    DNS常见攻击与防范 转自:http://www.williamlong.info/archives/3813.html 日期:2015-7-10 随着网络的逐步普及,网络安全已成为INTERNET路 ...

  10. Linux升级安装GCC G++ 6.2

    使用yum安装是不可能了,各大仓库也没有,只能自己编译安装了. 系统为CentOS 6.5,gcc为4.4.7 1 下载源代码包 当前最新版为6.2: wget http://ftp.gnu.org/ ...