Java集合框架-1

news/2024/7/7 19:31:37

目录

List集合

常见方法

迭代器(Iterator)

List集合特有方法

List 的特点

创建 List

遍历List


Java集合框架是Java编程语言提供的各种数据结构和算法的实现。它提供了不同类型的集合类,如列表(List)、集(Set)、映射(Map)等,以及一组接口和类来操作和处理集合数据。

Java集合框架的主要类和接口包括:

1. Collection接口:它是所有集合类的根接口,定义了集合对象的基本方法,如添加、删除、查询等。常见的实现类有List和Set。

2. List接口:它是有序的集合,允许重复元素。常见的实现类有ArrayList、LinkedList和Vector。

3. Set接口:它是无序的集合,不允许重复元素。常见的实现类有HashSet、TreeSet和LinkedHashSet。

4. Map接口:它是一种键值对的集合,每个元素包含一个键和一个值。常见的实现类有HashMap、TreeMap和LinkedHashMap。

集合框架提供了许多通用的方法,如add()、remove()和contains()等,以便操作集合中的元素。此外,它还提供了迭代器(Iterator)来遍历集合中的元素。

Java集合框架的好处包括:
- 提供了丰富的数据结构和算法的实现,方便开发者使用和操作集合数据。
- 统一了集合类的接口和方法,使得代码更加简洁、可读性更高。
- 提供了线程安全和高效的实现,能够处理大量数据和高并发情况。
- 可以与其他Java类库和框架很好地集成,提供更强大的功能和性能。

总之,Java集合框架是Java编程中非常重要和常用的一部分,它提供了大量的集合类和接口,方便开发者进行集合操作和处理。通过熟悉集合框架的使用,可以提高程序的开发效率和性能。

List集合

常见方法
 List 是一个接口,它是最基础的一种集合:它是一种有序列表。它的常用子类包括:

ArrayList:基于动态数组实现,支持随机访问。

LinkedList:基于双向链表实现,只能顺序访问,但是可以快速地在链表中间插入和删除元素。不仅如此,LinkedList 还可以用作栈、队列和双向队列。

Vector:和 ArrayList 类似,但它是线程安全的。

Stack:它实现了一个标准的后进先出的栈,是 Vector 的子类。
CopyOnWriteArrayList:一个线程安全的 ArrayList。


import java.util.ArrayList;
import java.util.List;

public class Arraylist_test01 {
    public static void main(String[] args) {
        new ArrayList<>();
        /**
         * new ArrayList<泛型>();
         */
        List<String> arrayList = new ArrayList<String>(); //右边的泛型可不写!

        arrayList.add("wo"); //向集合存入元素 , 但是要和定义的类型一样!
        arrayList.add("ni");
        arrayList.add("ta");

        //ArrayList 底层是基于数组的

        System.out.println(arrayList.size()); //ArrayList.size 方法可以清楚的看到集合中元素的数量! //3


        for (int i = 0; i < arrayList.size(); i++) {
            System.out.println(arrayList.get(0)); //将下标为0的数组循环三次并打印出来!
        }
        System.out.println(arrayList.get(0) + arrayList.get(1) + arrayList.get(2)); // ArrayList.get方法 可以获取到集合中的元素!

//        System.out.println(arrayList.get(0) + arrayList.get(1) + arrayList.get(2) + arrayList.get(3)); //一定会报错的!获取的元素不能超过集合中的元素数量!


        System.out.println("-----------------------------------");
        String remove = arrayList.remove(2);
        System.out.println(remove); // ArrayList.remove 删除元素! //ta

//        System.out.println(arrayList.get(0) + arrayList.get(1) + arrayList.get(2)); // 会报错!因为下标为2的元素已经删除了!
        System.out.println(arrayList.size()); // 2  使用size方法,会得到集合中还有两个元素!!
    }
}




ArrayList.get : 获取集合中的元素
ArrayList.set : 替换集合中的元素
ArrayList.add : 给集合添加元素
ArrayList.remove : 删除集合中的元素
ArrayList.size   : 获取集合中元素的数量


迭代器(Iterator)
在 Java 中,迭代器(Iterator)是一种用于遍历集合(Collection)元素的接口。通过迭代器,可以依次访问集合中的每个元素,而无需了解集合内部的数据结构。使用迭代器可以实现对集合的遍历,并且在遍历的过程中可以进行删除操作,而不会出现并发修改异常。

通常,使用迭代器的基本流程如下:

1. 通过集合的 iterator() 方法获取迭代器对象。
2. 使用 hasNext() 方法判断是否还有下一个元素。
3. 使用 next() 方法获取下一个元素的值。
4. 在需要的时候可以使用 remove() 方法删除元素(可选操作)。

需要注意的是,迭代器是通过集合的 iterator() 方法获取的,不同的集合类(如ArrayList、LinkedList、HashSet等)都实现了iterator()方法,因此可以使用迭代器对不同类型的集合进行遍历操作。

import java.util.ArrayList;
import java.util.Iterator;

public class IteratorExample {
    public static void main(String[] args) {
        ArrayList<String> list = new ArrayList<>();
        list.add("A");
        list.add("B");
        list.add("C");

        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            String element = iterator.next();
            System.out.println(element);
        }
    }
}

List集合特有方法


import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;

public class ArrayList_list {
    public static void main(String[] args) {

        //list接口中独有的方法
        Collection<String> collection = new ArrayList<>();
        collection.add("qq01");
        collection.add("qq02");
        collection.add("qq03");
        //在Collenction接口中,是没有get方法的、
        //java多态机制  -- 编译看左边的  而左边是Collection接口,没有get方法,所以运行报错!!

        //如果需要使用get方法,可以将Collection强转为List即可!
        List list = (List) collection;
//        System.out.println(list.get(0)); // 这样就可以使用get方法了!

        list.add("qq123");
//        System.out.println(list.size()); // 4

        list.remove(2);
//        System.out.println(list.size()); //3

        list.set(1, "weixin");
        Iterator iterator = list.iterator();
        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }
    }
    /**
     * collection 接口只是提供集合基本的方法
     * 具体实现的话使用List ArratList ,需要重写List接口!
     *
     * 1、List集合下都是有序的接口  根据存放顺序
     * 2、可以允许存放重复数据的,而set接口不允许!
     */
}


List 的特点
  • 使用 List 时,我们要关注 List 接口的规范。List 接口允许我们添加重复的元素,即 List 内部的元素可以重复:
1List<String> list = new ArrayList<>();

2list.add("apple");           // size=1

3list.add("pear");           // size=2

4list.add("apple");           // 允许重复添加元素,size=3

5System.out.println(list.size());                  // 结果为 3
  • List 还允许添加 null
1List<String> list = new ArrayList<>();

2list.add("apple");         // size=1

3list.add(null);               // size=2

4list.add("pear");         // size=3

5String second = list.get(1);                  // null

6System.out.println(second);            // 结果为 3

List集合的概念和特点

1、list集合是有序的,可以精确的控制列表中每个元素的插入位置!可以通过证书索引访问元素,并搜索列表中的元素!!

2、set集合是无序的,不允许存入重复的数据!

List集合的特点
有序:存储和取出的元素顺序一致!
可重复:存储的元素可以重复!

创建 List

除了使用 ArrayListLinkedListJDK9 及其以后的版本中,我们还可以通过 List 接口提供的 of() 方法,根据给定元素快速创建 List

1List<Integer> list = List.of(1, 2, 3);

注意:但是 List.of() 方法不接受 null 值,如果传入 null,会抛出 NullPointerException 异常。


遍历List

1、for循环:和数组类型,我们要遍历一个 List,完全可以用 for 循环根据索引配合 get(int) 方法遍历:

List<String> list = List.of("apple", "pear", "banana");
for (int i = 0; i < list.size(); i++) {
    String s = list.get(i);
    System.out.println(s);
}

2、迭代器:Iterator 对象有两个方法:boolean hasNext() 判断是否有下一个元素,E next() 返回下一个元素。因此,使用 Iterator 遍历 List 代码如下

List<String> list = List.of("apple", "pear", "banana");
for (Iterator<String> it = list.iterator(); it.hasNext(); ) {
    String s = it.next();
    System.out.println(s);
}

3、加强版 for 循环:Javafor each 循环就可以帮我们使用 Iterator 遍历。把上面的代码再改写如下:

List<String> list = List.of("apple", "pear", "banana");
for (String s : list) {
    System.out.println(s);
}

练习:

import java.util.Iterator;
import java.util.List;
import java.util.ArrayList;

public class Solution {
    public void myMethod() throws Exception{
        List<String> list = new ArrayList<>();
        list.add("apple");
        list.add("pear");
        list.add("banana");
        System.out.println("使用普通的for循环遍历:");
        for (int i=0; i<list.size(); i++) {
            String s = list.get(i);
            System.out.println(s);
        }

        System.out.println("使用迭代器Iterator遍历:");
        for (Iterator<String> it = list.iterator(); it.hasNext(); ) {
            String s = it.next();
            System.out.println(s);
        }

        System.out.println("使用增强版for循环:");
        for (String s : list) {
            System.out.println(s);
        }
    }
}


http://lihuaxi.xjx100.cn/news/2039427.html

相关文章

Hive中几种常见的表

Hive的表类型主要有&#xff1a;内部表&#xff08;受控表/管理表&#xff09;、外部表、临时表、分区表、分桶表。 1. 内部表&#xff08;管理表&#xff09; 默认创建的表都是管理表/内部表&#xff0c;表数据默认存储在warehouse目录中&#xff0c;在加载数据的过程中&…

ArcGIS中查看栅格影像最大值最小值的位置

如果只是想大概获取栅格影像中最大值最小值的位置进行查看&#xff0c;可以不用编写程序获取具体的行列信息&#xff0c;只需要利用分类工具即可。 假设有一幅灰度影像数据&#xff0c;如下图所示。 想要查看最大值2116的大概位置在哪里&#xff0c;可以右击选择图层属性&…

Java多线程系列——CAS机制

在并发编程的世界里&#xff0c;线程安全是个不得不面对的问题&#xff0c;而CAS&#xff08;Compare-And-Swap&#xff0c;比较并交换&#xff09;正是保障并发安全中一种非常关键的机制。本文将深入剖析Java多线程环境下的CAS机制&#xff0c;包括其工作原理、实现方式、面临…

基础数据结构与相关C++ STL容器

文章目录 数组arrayvector 栈和队列dequestackqueue 堆heappriority_queue 链表listforward_list 树setmapmultisetmultimap 哈希表unordered_setunordered_mapunordered_multisetunordered_multimap 图 数组 array 不开口的连续线性空间&#xff0c;支持随机访问。 array是…

字符串哈希相关例题题解

一.P2957 [USACO09OCT] Barn Echoes G 这道题在前介绍KMP算法时&#xff0c;当做例题&#xff0c;当然我也提到这道题可以通过字符串哈希来完成&#xff0c;所以现在我们来使用字符串哈希来解决&#xff0c;用字符串哈希的思路很明显&#xff0c;前后两次比较&#xff0c;然后取…

Python 3 中,`asynchat`异步通信

在 Python 3 中&#xff0c;asynchat 是基于 asyncore 的一个高层抽象模块&#xff0c;用于处理异步通信协议。它提供了一种简单的方式来创建自定义的异步通信协议&#xff0c;并处理通信中的错误和异常。 asynchat 模块主要作用是将网络数据流分割成消息或者数据包&#xff0…

2025年考研数学(三)备考必备:2015-2024年考研数学真题练一练

今天&#xff0c;我们来分享2015年-2024年的考研数学三选择题&#xff0c;随机做5道真题&#xff0c;并提供解析。看看正在备考2025年考研的你能做对几道。 考研数学和政治、英语一项&#xff0c;都是拉分大户&#xff0c;但是数学如果掌握了技巧&#xff0c;吃透了知识点的话比…

五种多目标优化算法(MOJS、MOGWO、NSWOA、MOPSO、NSGA2)性能对比(提供MATLAB代码)

一、5种多目标优化算法简介 1.1MOJS 1.2MOGWO 1.3NSWOA 1.4MOPSO 1.5NSGA2 二、5种多目标优化算法性能对比 为了测试5种算法的性能将其求解9个多目标测试函数&#xff08;zdt1、zdt2 、zdt3、 zdt4、 zdt6 、Schaffer、 Kursawe 、Viennet2、 Viennet3&#xff09;&#xff0…