1.Collection集合

1.1数组和集合的区别【理解】

  • 相同点

    都是容器,可以存储多个数据

  • 不同点

    • 数组的长度是不可变的,集合的长度是可变的

    • 数组可以存基本数据类型和引用数据类型

      集合只能存引用数据类型,如果要存基本数据类型,需要存对应的包装类

1.2集合类体系结构【理解】

1.3Collection 集合概述和使用【应用】

  • Collection集合概述

    • 是单例集合的顶层接口,它表示一组对象,这些对象也称为Collection的元素

    • JDK 不提供此接口的任何直接实现.它提供更具体的子接口(如Set和List)实现

  • 创建Collection集合的对象

    • 多态的方式

    • 具体的实现类ArrayList

  • Collection集合常用方法

    方法名 说明
    boolean add(E e) 添加元素
    boolean remove(Object o) 从集合中移除指定的元素
    boolean removeIf(Object o) 根据条件进行移除
    void clear() 清空集合中的元素
    boolean contains(Object o) 判断集合中是否存在指定的元素
    boolean isEmpty() 判断集合是否为空
    int size() 集合的长度,也就是集合中元素的个数

1.4Collection集合的遍历【应用】

  • 迭代器介绍

    • 迭代器,集合的专用遍历方式

    • Iterator<E> iterator(): 返回此集合中元素的迭代器,通过集合对象的iterator()方法得到

  • Iterator中的常用方法

    boolean hasNext(): 判断当前位置是否有元素可以被取出 ​ E next(): 获取当前位置的元素,将迭代器对象移向下一个索引位置

  • Collection集合的遍历

     1 public class IteratorDemo1 {
    2 public static void main(String[] args) {
    3 //创建集合对象
    4 Collection<String> c = new ArrayList<>();
    5 ​
    6 //添加元素
    7 c.add("hello");
    8 c.add("world");
    9 c.add("java");
    10 c.add("javaee");
    11 ​
    12 //Iterator<E> iterator():返回此集合中元素的迭代器,通过集合的iterator()方法得到
    13 Iterator<String> it = c.iterator();
    14 ​
    15 //用while循环改进元素的判断和获取
    16 while (it.hasNext()) {
    17 String s = it.next();
    18 System.out.println(s);
    19 }
    20 }
    21 }
  • 迭代器中删除的方法

    void remove(): 删除迭代器对象当前指向的元素

     1 public class IteratorDemo2 {
    2 public static void main(String[] args) {
    3 ArrayList<String> list = new ArrayList<>();
    4 list.add("a");
    5 list.add("b");
    6 list.add("b");
    7 list.add("c");
    8 list.add("d");
    9 ​
    10 Iterator<String> it = list.iterator();
    11 while(it.hasNext()){
    12 String s = it.next();
    13 if("b".equals(s)){
    14 //指向谁,那么此时就删除谁.
    15 it.remove();
    16 }
    17 }
    18 System.out.println(list);
    19 }
    20 }

1.5增强for循环【应用】

  • 介绍

    • 它是JDK5之后出现的,其内部原理是一个Iterator迭代器

    • 实现Iterable接口的类才可以使用迭代器和增强for

    • 简化数组和Collection集合的遍历

  • 格式

    for(集合/数组中元素的数据类型 变量名 : 集合/数组名) {

    // 已经将当前遍历到的元素封装到变量中了,直接使用变量即可

    }

  • 代码

     1 public class MyCollectonDemo1 {
    2 public static void main(String[] args) {
    3 ArrayList<String> list = new ArrayList<>();
    4 list.add("a");
    5 list.add("b");
    6 list.add("c");
    7 list.add("d");
    8 list.add("e");
    9 list.add("f");
    10 ​
    11 //1,数据类型一定是集合或者数组中元素的类型
    12 //2,str仅仅是一个变量名而已,在循环的过程中,依次表示集合或者数组中的每一个元素
    13 //3,list就是要遍历的集合或者数组
    14 for(String str : list){
    15 System.out.println(str);
    16 }
    17 }
    18 }

2.List集合

2.1List集合的概述和特点【记忆】

  • List集合的概述

    • 有序集合,这里的有序指的是存取顺序

    • 用户可以精确控制列表中每个元素的插入位置,用户可以通过整数索引访问元素,并搜索列表中的元素

    • 与Set集合不同,列表通常允许重复的元素

  • List集合的特点

    • 存取有序

    • 可以重复

    • 有索引

2.2List集合的特有方法【应用】

方法介绍

方法名 描述
void add(int index,E element) 在此集合中的指定位置插入指定的元素
E remove(int index) 删除指定索引处的元素,返回被删除的元素
E set(int index,E element) 修改指定索引处的元素,返回被修改的元素
E get(int index) 返回指定索引处的元素

示例代码

 1 public class MyListDemo {
2 public static void main(String[] args) {
3 List<String> list = new ArrayList<>();
4 list.add("aaa");
5 list.add("bbb");
6 list.add("ccc");
7 //method1(list);
8 //method2(list);
9 //method3(list);
10 //method4(list);
11 }
12 ​
13 private static void method4(List<String> list) {
14 // E get(int index) 返回指定索引处的元素
15 String s = list.get(0);
16 System.out.println(s);
17 }
18 ​
19 private static void method3(List<String> list) {
20 // E set(int index,E element) 修改指定索引处的元素,返回被修改的元素
21 //被替换的那个元素,在集合中就不存在了.
22 String result = list.set(0, "qqq");
23 System.out.println(result);
24 System.out.println(list);
25 }
26 ​
27 private static void method2(List<String> list) {
28 // E remove(int index) 删除指定索引处的元素,返回被删除的元素
29 //在List集合中有两个删除的方法
30 //第一个 删除指定的元素,返回值表示当前元素是否删除成功
31 //第二个 删除指定索引的元素,返回值表示实际删除的元素
32 String s = list.remove(0);
33 System.out.println(s);
34 System.out.println(list);
35 }
36 ​
37 private static void method1(List<String> list) {
38 // void add(int index,E element) 在此集合中的指定位置插入指定的元素
39 //原来位置上的元素往后挪一个索引.
40 list.add(0,"qqq");
41 System.out.println(list);
42 }
43 }

3.数据结构

3.1数据结构之栈和队列【记忆】

栈结构

先进后出

队列结构

先进先出

3.2数据结构之数组和链表【记忆】

数组结构

查询快、增删慢

队列结构

查询慢、增删快

4.List集合的实现类

4.1List集合子类的特点【记忆】

ArrayList集合

底层是数组结构实现,查询快、增删慢

LinkedList集合

底层是链表结构实现,查询慢、增删快

4.2LinkedList集合的特有功能【应用】

特有方法

方法名 说明
public void addFirst(E e) 在该列表开头插入指定的元素
public void addLast(E e) 将指定的元素追加到此列表的末尾
public E getFirst() 返回此列表中的第一个元素
public E getLast() 返回此列表中的最后一个元素
public E removeFirst() 从此列表中删除并返回第一个元素
public E removeLast() 从此列表中删除并返回最后一个元素

示例代码

 1 public class MyLinkedListDemo4 {
2 public static void main(String[] args) {
3 LinkedList<String> list = new LinkedList<>();
4 list.add("aaa");
5 list.add("bbb");
6 list.add("ccc");
7 // public void addFirst(E e) 在该列表开头插入指定的元素
8 //method1(list);
9 ​
10 // public void addLast(E e) 将指定的元素追加到此列表的末尾
11 //method2(list);
12 ​
13 // public E getFirst() 返回此列表中的第一个元素
14 // public E getLast() 返回此列表中的最后一个元素
15 //method3(list);
16 ​
17 // public E removeFirst() 从此列表中删除并返回第一个元素
18 // public E removeLast() 从此列表中删除并返回最后一个元素
19 //method4(list);
20
21 }
22 ​
23 private static void method4(LinkedList<String> list) {
24 String first = list.removeFirst();
25 System.out.println(first);
26 ​
27 String last = list.removeLast();
28 System.out.println(last);
29 ​
30 System.out.println(list);
31 }
32 ​
33 private static void method3(LinkedList<String> list) {
34 String first = list.getFirst();
35 String last = list.getLast();
36 System.out.println(first);
37 System.out.println(last);
38 }
39 ​
40 private static void method2(LinkedList<String> list) {
41 list.addLast("www");
42 System.out.println(list);
43 }
44 ​
45 private static void method1(LinkedList<String> list) {
46 list.addFirst("qqq");
47 System.out.println(list);
48 }
49 }
50
51

Java_集合之一的更多相关文章

  1. Java_集合面试题

    Java_集合面试题 0.链表,队列和栈的区别? 链表是一种存储结构,指得是存储时候除了要存储数据元素之外,还要用数据元素一起的另外空间存储数据元素的关系. 队列和栈都是线性表,属于逻辑结构范畴,都是 ...

  2. JAVA_集合框架虐我千百遍,虐也是一种进步

    1.Collection和Collections区别: Collection是java的一个集合接口,集合类的顶级接口 Collections是一个包装类(工具类),不能被实例化(由于其构造函数设为私 ...

  3. java_集合框架

    一.集合框架图 二.Collection接口     Collection中可以存储的元素间无序,可以重复的元素.     Collection接口的子接口List和Set,Map不是Collecti ...

  4. java_ 集合

    集合类说明及区别Collection├List│├LinkedList│├ArrayList│└Vector│ └Stack└SetMap├Hashtable├HashMap└WeakHashMap ...

  5. Java_集合

    定义: 是一种工具,就像是容器,能存储任意数量的具有共同属性的对象. 与数组比较优点: (1)数组定义后长度不可变,集合长度可变: (2)数组只能通过下标访问,且下标类型只能是数字型,而有的集合(ma ...

  6. Java_集合与泛型

    Collection 集合,集合是java中提供的一种容器,可以用来存储多个数据.在前面的学习中,我们知道数据多了,可以使用数组存放或者使用ArrayList集合进行存放数据.那么,集合和数组既然都是 ...

  7. Java_集合总结

    集合分类 Collection 接口是集合的父类 1.Set 集合 使用内部的排列机制(无序),存入集合的顺序和取出集合的顺序不一致,没有索引,存入集合的元素没有重复 HashSet集合 Linked ...

  8. 【Java_集合框架Set】HashSet、LinkedHashSet、TreeSet使用区别

    HashSet:哈希表是通过使用称为散列法的机制来存储信息的,元素并没有以某种特定顺序来存放: LinkedHashSet:以元素插入的顺序来维护集合的链接表,允许以插入的顺序在集合中迭代: Tree ...

  9. Java_集合之三

    1.红黑树 1.1概述[理解] 红黑树的特点 平衡二叉B树 每一个节点可以是红或者黑 红黑树不是高度平衡的,它的平衡是通过"自己的红黑规则"进行实现的 红黑树的红黑规则有哪些 每一 ...

随机推荐

  1. x64dbg 条件断点相关文档

    输入 字符格式 条件断点 Input When using x64dbg you can often use various things as input. Commands Commands ha ...

  2. pta 简单求和

    6-1 简单求和 (10 分)   本题要求实现一个函数,求给定的N个整数的和. 函数接口定义: int Sum ( int List[], int N ); 其中给定整数存放在数组List[]中,正 ...

  3. 通俗易懂,android是如何管理内存的

    封面来源:https://medium.com/android-news/android-performance-patterns-rescue-tips-8c1e4c7cb1f0 前言 很高兴遇见你 ...

  4. 有了CMDB,为什么还需要应用配置管理?

    有了CMDB,为什么还需要应用配置管理? 你不妨先停下来,思考一下这个问题. 我抛出的观点是: CMDB是面向资源的管理,应用配置是面向应用的管理. 请注意,这里是面向"资源",不 ...

  5. lustre文件系统环境搭建及测试

    目录 1.节点角色 2.硬件配置 3.软件版本 4.安装软件包 4.1.安装 e2fsprogs 相关包 4.2.安装 kernel 相关包 4.3.客户端安装 4.4.服务器端安装 4.5.配置 5 ...

  6. 一文简述Java IO

    Java IO 本文记录了在学习Java IO过程中的知识点,用于复习和快速查阅,不够详细的部分可能会在后续补充. 什么是流 流:内存与存储设备(外存)之间传输数据的通道 IO:输入流输出流(如rea ...

  7. 死磕Spring之AOP篇 - Spring AOP自动代理(一)入口

    该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读. Spring 版本:5.1 ...

  8. E - Minimal Subarray Length(连续区间和)

    题目链接 题意:给出n个数,求加和大于x的最短区间的区间长度. 如果前i个数字和为y,那么如果前j数字的和小于等于y-x,那么i-j就是一种可能的情况,我们对于所有的i找出前面最大的j就可以了,因为数 ...

  9. hdu4530 水题

    题意: 小Q系列故事--大笨钟 Time Limit: 600/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total ...

  10. hdu 1814 字典序最小的2sat(暴力深搜)

    题意:      题意就是最基础的2sat,关系只有矛盾关系,然后二选一,关键是这个题目是输出字典序最小的那组解. 思路:      输出字典序最小,用强连通那个实现不了(起码没看到有人实现),其实我 ...