一、Map接口

1、 Map接口就是最顶层了,上面没有继承了。Map是一个容器接口,它与前面学的List.Set容器不同的是前面学的这些容器,一次只能传入一个元素,但是Map容器一次可以传入一对元素(键值对),这个键值对是封装在entry对象内部的,一个entry对象就是一个键值对。 Map容器的特点:键是不能重复的,值是可以重复的,并且一个键只能对应一个值。Set 容器也是无序不可重复的 Map接口和Collection接口是两个并列的没有任何关系的集合(都是接口) Map接口下面有HashMap集合、TreeMap集合、Hashtable集合;Hashtable集合下面有properties集合。

二、HashMap集合

1、HashMap是无序的,不可重复的(判断重复的标准是键值对的键不能重复,也是通过HashCode方法和equals方法来判断的), HashMap的底层也是数组加链表实现的(HashSet底层也都是数组加链表的结构实现的)HashMap可以用null作为键和值,并且是线程不安全的

  HashMap构造方法:

  HashMap() 创建一个HashMap对象

  HashMap(Map m)  创建一个键值对与m相同的HashMap集合

2、HashMap常用方法

V put(K key, V value) 添加/修改指定的映射                   返回的是: 被替换的值

boolean containsKey(Object key)   判断map容器是否包含指定的键

boolean containsValue(Object value) 判断map容器是否包含指定的值

V get(Object key)   根据指定的键获取指定的值

void putAll(Map m) 把m集合中所有的元素,添加到当前map容器中

V remove(Object key) 根据指定的键删除对应的映射

int size()   获取map容器中元素的个数

void clear() 移除所有映射关系。

boolean isEmpty()    判断map容器是否为空,  为空返回true,否则返回false

3、HashMap循环相关的方法:

Collection values()   获取map中所有的值

Set  keySet()         获取map中所有的键

Set  entrySet()       获取map所有的entry对象

Map接口没有继承Iterable接口所以不能使用增强for循环和迭代器循环。

三、Collections工具类

Arrays工具类是sun公司为我们提供的一个专门操作数组的类

Collections工具类是sun公司为我们提供的专门操作集合的类

1、常用方法

static T  max(Collection coll)  获取集合中最大元素

static T max(Collection coll, Comparator comp)  根据比较器获取最大的元素

static T  min(Collection coll) 获取集合中最小元素

static T  min(Collection coll, Comparator comp)  根据比较器获取最小元素

static void reverse(List list)   反转指定列表中元素的顺序。

static void shuffle(List list)  随机打乱集合中的元素

static  void sort(List list)  根据元素的自然顺序 对指定列表按升序进行排序。

static  void sort(List list, Comparator c)  根据指定比较器产生的顺序对指定列表进行排序。

static  List emptyList()   返回空的列表(不可变的)。

static  Map emptyMap() 返回空的映射(不可变的)。

static  Set emptySet() 返回空的 set(不可变的)。

注意:以上三个方法都仅仅表示一种状态而已

四、Hashtable集合

Hashtable和HashMap的区别:

Hashtable是HashMap的前身,Hashtable是线程安全的,而HashMap是线程不安全的,所以HashMap性能要比Hashtable高

Hashtable不能以null作为键和值,而HashMap是允许的(集合中就只有Hashtable不能使用null作为值)

五、TreeMap

TreeMap集合是无序不可重复的,底层都是使用二叉树实现的,这个集合默认是自然排序,也可以使用定制排序(比较器)

要想往TreeSet容器和TreeMap容器中存储数据,那么数据必须要按照一定的顺序排序才能存储

一、Propertites集合

Properties容器是Hashtable容器的子类,他操作的数据也是无序的不可重复的键值对,并且要求键和值都必须是字符串;除此之外,Properties容器的操作方法不能使用继承而来的,因为这样会让他失去自己的意义

1、 常用方法

Object setProperty(String key, String value) 调用 Hashtable 的方法 put。

public String getProperty(String key)取值  根据指定的key获取对应的值 。

public String getProperty(String key, String defaultValue)  根据指定的key获取对应的值,如果没找到,则直接返回defaultValue对应的值

void list(PrintStream out)  把内存里面的数据同步到磁盘上

pp.list(new PrintStream("D:/Java学习资料/资料/2019-04-13-集合框架-Set-DAY20/resources/abc.txt"));//这是绝对路径

pp.list(new PrintStream("a.txt")//这是相对路径 ,相对于当前项目的路径, 这个文件会存在当前项目的根路径 (当前项目的根路径:当前项目打开第一层,就称为根路径)

void load(InputStream inStream)  简单理解把磁盘中的数据读取到内存中

二、泛型

泛型:它是一个泛指,简单理解就是约束着容器只能装某一类型的值

我们只需要在创建对象的时候再具体写出泛型的具体类型。

泛型的注意事项:添加泛型的时候,必须添加引用数据类型,不能添加基本数据类型

泛型有个规范:

E:  element  元素

T:  Type     类型

K:  key      键

V:  value    值

当我们在开发中不确定使用什么数据类型是,就可以使用泛型,避免重复的更改数据类型

泛型的上限和下限:简单记忆:上有顶,下有底,意思就是? extends 引用数据类型  A,你传递的泛型必须是A或者A的子孙类;? super 引用数据类型B,你传递的泛型必须是B或者B的父类

? 是一个通配符,代表任意泛型。

我们最常用泛型的方式:   new  ArrayList<String>();

new HashMap<String,Integer>();

class IntArr<T>;

Map接口下的集合和泛型理解的更多相关文章

  1. List接口下的集合

    集合框架 List接口下的集合特点: Set接口下的集合特点: 1.都是有序的 1.都是无序的 2.都有下标 2.没有下标 3.都可以重复 3.不可重复(覆盖) List接口下的集合 1.ArrayL ...

  2. JAVA笔记20-容器之四Map接口、自动打包、泛型(重要)

    一.Map接口 Map提供的是key到value的映射.key不能重复,每个key只能映射一个value. 注:重复是指equals,但用equals()方法效率低,所以此处用hashCode()方法 ...

  3. Set接口下的集合

    一.集合(定义字段的时候统一使用包装类) 1.集合大类分为List.Set.Map三种,其中,List集合是有序可重复的,并且可以使用普通for循环.增强for循环.正向迭代器.双向迭代器:Set集合 ...

  4. JavaSet接口、唯一元素和Map接口整理

    Set接口 1.1 HashSet集合存储数据的结构(哈希表) HashSet集合,采用哈希表结构存储数据,保证元素唯一性的方式依赖于:hashCode()与equals()方法. 哈希表底层,使用的 ...

  5. Java学习(Map接口)

    一.概述: 我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同,如下图. 1. Collection中的集合,元素是孤立存在的(理解为单身), ...

  6. JAVA基础之Map接口

    个人理解: 个人感觉Map接口以后会经常用到,可以很清晰地查找某个对象,要熟悉其四种遍历方法.特别注意其键值对的键不能是重复的,有想定义有序存取的话,可以使用LinkedHashMap集合.不过定义自 ...

  7. 集合之六:Map接口

    Map接口概述 Map接口中的集合和Collection接口中的集合在存储数据的格式上有很大的不同,Map接口下的内容是以<K , V> ,键值对的形式存储的,我们查询API,Map接口的 ...

  8. Java中的集合(七)双列集合顶层接口------Map接口架构

    Java中的集合(七)双列集合顶层接口------Map接口 一.Map接口的简介 通过List接口,我们知道List接口下的集合是单列集合,数据存储是单列的结构.Map接口下是一个键值对(key-v ...

  9. Java—Map接口中的常用方法

    Map接口与Collection接口的区别 Collection中的集合,元素是孤立存在的(理解为单身),向集合中存储元素采用一个个元素的方式存储. Map中的集合,元素是成对存在的(理解为夫妻).每 ...

随机推荐

  1. 各类聚类(clustering)算法初探

    1. 聚类简介 0x1:聚类是什么? 聚类是一种运用广泛的探索性数据分析技术,人们对数据产生的第一直觉往往是通过对数据进行有意义的分组.很自然,首先要弄清楚聚类是什么? 直观上讲,聚类是将对象进行分组 ...

  2. UI命名规范

    Ui控件汇总 按钮 单行文本框 多行文本框 水平滑动条 垂直滑动条 水平滚动条 垂直滚动条 进度条 下拉列表框 复选框 UI命名规范 UI文字做好备份,方便后期维护修改 按钮命名规范:btn_ 第一个 ...

  3. 010 socket定义服务器

    using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Ne ...

  4. 目前的.NET 主流的后端ORM框架

    转自:https://www.cnblogs.com/yeminglong/p/9518438.html  推荐一些常用的asp.net ORM框架 SqlSugar (国内) Dos.ORM (国内 ...

  5. node-fs文件系统模块

    在node环境中所有与文件操作都是通过fs核心模块实现的.包括文件的创建.删除.查询以及读写和写入 在 fs 模块中,所有的方法都分为同步和异步两种实现,具有 sync 后缀的方法为同步方法,不具有 ...

  6. html的分类与特点

    ##块级元素##|元素|描述||--|--||h1-h6|标题||div|区分大模块||p|段落||ul>li|无序列表||ol>li|有序列表||dl>dt dd|自定义列表||t ...

  7. EF提交插入数据catch捕获具体异常方法

    try { db.SaveChanges(); } catch (DbEntityValidationException ex) { StringBuilder errors = new String ...

  8. 关于HashSet集合add元素

    HashSet集合add元素底层实现使用的是HashMap. 简单记忆:无论HashMap put元素还是HashSet add元素,都先调用hashCode()方法,若hashCode方法返回值不同 ...

  9. go之路

    目录 go初识[第一篇]初识 go初识[第二篇]包.变量.函数

  10. ueditor接入秀米编辑器

    秀米编辑器用来编辑微信页面很方便,功能也比较强大.秀米提供了第三方编辑器接入的功能,接入方法可以参照官网示例:http://hgs.xiumi.us/uedit/ 但是这里有几点要注意: 1. 示例中 ...