两大框架图解







Collection接口

由第一张图,我们可以知道,Collection接口的子接口有三种,分别是List接口,Set接口和Queue接口

List接口

允许有重复的元素,元素按照添加的顺序进行排序

  1. 接口方法

    • void add(int index,Objext o) 在集合的指定位置插入元素
    • Object get(int index) 返回集合中某个指定位置的元素
    • int indexOf(Object o) 返回第一次出现该元素的索引(下标),如果不包含此元素,返回-1
    • int lastIndexOf(Object o) 返回最后一次出现该元素的索引(下标),如果不包含此元素,返回-1
    • Object remove(int index) 移除集合某个索引的元素
    • Object set(int index,Object o) 用指定的元素替换集合中某个指定下标的数据元素
  2. 接口实现类的使用

    • ArrayList

      新增方法:

      addFirst

      getFirst

      removeFirst

      addLast

      getLast

      removeLast

      特点:在存储方式上是采用数组进行顺序存储

        List list = new ArrayList();
      List<泛型> list = new ArrayList<>();
    • LinkedList

      特点:在存储方式上是采用链表进行链式存储

        LinkedList<> list = new LinkedList<>();

PS:由于ArrayList是采用数组进行存储的,所以添加元素或者是删除元素时,需要批量移动元素,所以性能较差。但查询元素的时候,可以通过下标直接进行访问,所以遍历元素或随机访问元素的时候效率高。

而LinkedList与ArrayList相反

list迭代

如果想在list的迭代中操作list中的元素,例如删除,添加,使用listiterator,listiterator有add,set,remove

List<Book> books = new ArrayList<>();
//添加数据
for (int i = 1; i < 10; i++) {
Book book = new Book();
book.setBno("00" + i);
books.add(book);
}
System.out.println(books.size());
//通过ListIterator在遍历删除数据
ListIterator<Book> bookListIterator = books.listIterator();
String bno = "002";
while (bookListIterator.hasNext()) {
Book next = bookListIterator.next();
if (next.getBno().equals(bno)) {
bookListIterator.remove();
break;
}
}
//输出结果测试
System.out.println("-----");
System.out.println(books.size());
for (Book book : books) {
System.out.println(book.toString());
}

Set接口

不允许有重复的元素,元素没有顺序

  1. 接口方法

    add clear contains remove

    和之前的List差不多,这里就不多说

  2. 接口实现类的使用

    • HashSet

      下面的图片很明显,体现了没有重复元素的规则

        **一般使用的话还是使用泛型使用**
      
        	Set<Book> books = new HashSet<>();
    • TreeSet

      由之前介绍的第四张图可以看到,TreeSet既继承了Set接口,也继承了SortedSet接口(排序接口)

      没有使用泛型,默认使用的是String类型,String类实现了Comparable接口,默认是按字典排序,但是图中明显没有实现排序?不理解。。

      我使用英文开头,才能实现排序

    • Set集合遍历

    //Iterator
    Iterator iterator = set.iterator();
    while (iterator.hasNext()){
    System.out.println(iterator.next());
    }
    //foreach
    for (String s:set) {
    System.out.println(s);
    }

Queue接口

较少使用。。

Map接口

使用键值对(key value)进行数据存储,key与value是一种映射关系
  1. 接口方法

    • Object put(Object key,Object value) 将一个键值对存到Map中
    • Object get(Object key) 由key获得value
    • Object remove(Object key) 删除该键值对
    • Set keyset() 返回当前包含当前map的所有key的Set集合
    • Collection values() 返回当前包含当前map的所有value的Collection集合
    • boolean containsKey(Object key) 是否包含某个key
    • boolean containsValue(Object Value) 是否包含某个Value
    • int size() 返回当前map集合键值对的个数
  2. 接口实现类的使用

    • HashMap的使用

      Map<String,String> map = new HashMap<>();

      Map<Integer,String> map = new HashMap<>();

    PS: 一般在开头声明键值对的类型,如果在后面声明的话,很大可能会报错

    • TreeMap的使用

      Map<String,String> map = new TreeMap<>();

    与之前的TreeSet一样,TreeMap也是实现了SortedMap借口,带有排序,默认是按照key的数值自然排序(也就是升序)

Java 学习笔记 两大集合框架Map和Collection的更多相关文章

  1. Java学习笔记32(集合框架六:Map接口)

    Map接口与Collection不同: Collection中的集合元素是孤立的,可理解为单身,是一个一个存进去的,称为单列集合 Map中的集合元素是成对存在的,可理解为夫妻,是一对一对存进去的,称为 ...

  2. Java学习笔记29(集合框架三:泛型)

    泛型的概念: 简单地讲,就是同一个方法(类),可以接受不同的数据类型并运行得到相对应的结果,不会出现安全问题 上一篇有一段这样的代码: 没有定义集合类型.迭代器类型 package demo; imp ...

  3. Java学习笔记31(集合框架五:set接口、哈希表的介绍)

    set接口的特点: 1.不包含重复元素 2.set集合没有索引,只能用迭代器或增强for循环遍历 3.set的底层是map集合 方法和Collection的方法基本一样 set接口的实现类HashSe ...

  4. Java学习笔记34(集合框架八:综合案例:模拟斗地主的洗牌发牌)

    规则: 1.54张扑克牌,有花色 2.顺序打乱,一人一张依次发牌,一人17张,留三张作为底牌 3.看牌:按大小王2A....43的序排列打印 示例: package demo; import java ...

  5. Java学习笔记30(集合框架四:List接口)

    List接口继承自Collection接口 具有重要的三大特点: 1.有序集合:存入和取出的顺序一致 2.此接口的用户可以对列表中每个元素插入位置精确的控制:可以通过索引操作 3.可以存储重复元素 L ...

  6. Java学习笔记27(集合框架一:ArrayList回顾、Collection接口方法)

    集合:集合是java中提供的一种容器,可以用来存储多个数据 集合和数组的区别: 1.数组的长度是固定的,集合的长度是可变的 2.集合中存储的元素必须是引用类型数据 对ArrayList集合的回顾 示例 ...

  7. Java学习笔记33(集合框架七:Collections工具类)

    数组有工具类,方面操作数组 集合也有工具类:Collections 常用方法示例: package demo; import java.util.ArrayList; import java.util ...

  8. Java学习笔记28(集合框架二:Iterator迭代器)

    Iterator接口,翻译成中文是迭代器 迭代器的概念通俗解释: java中有很多的集合,内部有各种存储方法,取出的方式也各不相同,是否可以有一种通用的方式来获取呢? 这种方式类似for循环遍历, 通 ...

  9. JAVA基础第五章-集合框架Map篇

    业内经常说的一句话是不要重复造轮子,但是有时候,只有自己造一个轮子了,才会深刻明白什么样的轮子适合山路,什么样的轮子适合平地! 我将会持续更新java基础知识,欢迎关注. 往期章节: JAVA基础第一 ...

随机推荐

  1. React state和props使用场景

    一个组件的显示状态可以由内部状态state.外部参数props所决定. props: 1.props 是从外部传进组件的参数,主要是父组件向子组件传递数据. 2.props 对于使用它的组件来说是只读 ...

  2. 权限系统设计-day02

    练习中的问题: 1,<s:url action="employee_input" />这个标签用来让struts自动生成请求的路径,struts生成的路径是一个全路径, ...

  3. Spring框架中<constructor-arg>与<property>理解

    配置文件的根元素是beans,每个组件使用bean元素来定义,bean元素可以有许多属性,其中有两个是必须的:id和class.id表示组件的默认名称,class表示组件的类型. 依赖注入的方式:  ...

  4. MySQL 5.7 忘记密码

    MySQL 5.7 忘记Root密码 用管理员身份运行cmd.然后使用命令进行: 1.打开MySQL>bin文件夹 >cd C:\mysql\mysql5.7.14\bin 2.停止mys ...

  5. Redis的7个应用场景

    一:缓存——热数据 热点数据(经常会被查询,但是不经常被修改或者删除的数据),首选是使用redis缓存,毕竟强大到冒泡的QPS和极强的稳定性不是所有类似工具都有的,而且相比于memcached还提供了 ...

  6. Java开发快速上手

    Java开发快速上手 前言 1.我的大学 2.对初学者的建议 3.大牛的三大特点 4.与他人的差距 第一章 了解Java开发语言 前言 基础常识 1.1 什么是Java 1.1.1 跨平台性 1.2 ...

  7. [Swift]LeetCode19. 删除链表的倒数第N个节点 | Remove Nth Node From End of List

    Given a linked list, remove the n-th node from the end of list and return its head. Example: Given l ...

  8. [Swift]LeetCode494. 目标和 | Target Sum

    You are given a list of non-negative integers, a1, a2, ..., an, and a target, S. Now you have 2 symb ...

  9. [Swift]LeetCode873. 最长的斐波那契子序列的长度 | Length of Longest Fibonacci Subsequence

    A sequence X_1, X_2, ..., X_n is fibonacci-like if: n >= 3 X_i + X_{i+1} = X_{i+2} for all i + 2 ...

  10. kubernetes系列之ConfigMap使用方式

    作用理解 核心用途就是容器和配置的分离解耦. 如启用一个mysql容器,mysql容器重要的文件有两部分,一部分为存储数据文件,一部分为配置文件my.cnf,存储数据可以用持久存储实现和容器的分离解耦 ...