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. PTA 有序数组的插入

    6-5 有序数组的插入 (20 分)   本题要求将任一给定元素插入从大到小排好序的数组中合适的位置,以保持结果依然有序. 函数接口定义: bool Insert( List L, ElementTy ...

  2. 使用 Kubernetes 扩展专用游戏服务器

    系列 探索使用 Kubernetes 扩展专用游戏服务器:第 1 部分-容器化和部署 探索使用 Kubernetes 扩展专用游戏服务器:第 2 部分-管理 CPU 和内存 探索使用 Kubernet ...

  3. 你说,怎么把Bean塞到Spring容器?

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 小傅哥,你是怎么学习的? 有很多初学编程或者码了几年CRUD砖的小伙伴问我,该怎么学 ...

  4. 在M1芯片的Mac系统上做.net core开发靠谱吗?

    作为一个7年老.NET程序员,最近几年苹果慢慢接替微软,成为我心中最酷的科技公司. 为什么我会选择Mac os作为我的开发环境? 很多做.net的同学都使用Windows系统作为自己的开发环境,我其实 ...

  5. 安装并配置Docker(基于Ubuntu)

    安装并配置Docker(基于Ubuntu) 目录 安装并配置Docker(基于Ubuntu) 一.安装Docker 二.验证Docker是否安装成功 三.配置Docker加速器 3.1 创建daemo ...

  6. List集合中的交集 并集和差集

    目录 List集合求交集 并集 差集 Set集合 Lambda表达式 List集合求交集 并集 差集 两种方法求集 Set集合 交集 两个集合中有相同的元素 抽取出来的数据就是为交集 @Test pu ...

  7. ABP 适用性改造 - 添加 API 版本化支持

    Overview 在前面的文章里有针对 abp 的项目模板进行简化,构建了一个精简的项目模板,在使用过程中,因为我们暴露的 api 需要包含版本信息,我们采取的方式是将 api 的版本号包含在资源的 ...

  8. (五)Struts2处理结果管理

    当Action处理完用户请求时,处理结果应该通过视图资源实现,但将哪个视图呈现给浏览者呢.由<result.../>来决定 Action处理完用户请求后,返回一个普通字符串.整个普通字符串 ...

  9. linux编译安装Apache

    1 前言 编译安装Apache HTTP Server,目前最新的版本为2.4.41,做好apr,apr-util,pcre的安装后编译安装即可. 2 准备工作 三个:apr,apr-util,pcr ...

  10. Digit Counting UVA - 1225

    ​ Trung is bored with his mathematics homeworks. He takes a piece of chalk and starts writing a sequ ...