当前位置: 首页 > article >正文

List和Map有什么区别?

1.是什么

    List 和 Map 是 Java 集合框架中的两个不同接口,它们用于存储不同类型的数据,并具有不同的行为和用途。


List 接口

  • 存储类型List 接口用于存储一系列有序的元素集合,允许重复元素。
  • 元素List 中的元素可以是任何对象,包括 null
  • 存储顺序List 接口保证了元素的有序性,元素在列表中的位置称为索引,索引从 0 开始。
  • 操作List 接口提供了丰富的操作,如 add(添加元素)、remove(删除元素)、get(根据索引获取元素)等。

Map 接口

  • 存储类型Map 接口用于存储键值对(key-value pairs),其中键是唯一的,而值可以重复。
  • 键值对:每个键值对都有一个键和一个值,键用于查找值。
  • 存储顺序Map 接口不保证元素的顺序,尽管一些实现类(如 TreeMap)会保持元素的排序。
  • 键和值:键和值可以是任何对象,包括 null
  • 操作Map 接口提供了丰富的操作,如 put(添加键值对)、get(根据键获取值)、remove(根据键删除键值对)等。

区别

  1. 存储类型List 存储一系列有序的元素,而 Map 存储键值对。
  2. 键和值List 中的元素可以是任意对象,而 Map 中的键是唯一的,值可以重复。
  3. 存储顺序List 接口保证了元素的有序性,而 Map 接口不保证元素的顺序。
  4. 操作List 提供了丰富的操作,如 add 和 remove,而 Map 提供了键值对的操作,如 put 和 get

示例

假设我们有一个包含字符串的集合:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.TreeMap;

public class ListMapExample {
    public static void main(String[] args) {
        // List 示例
        ArrayList<String> arrayList = new ArrayList<>();
        arrayList.add("Apple");
        arrayList.add("Banana");
        arrayList.add("Cherry");

        LinkedList<String> linkedList = new LinkedList<>();
        linkedList.add("Apple");
        linkedList.add("Banana");
        linkedList.add("Cherry");

        // Map 示例
        HashMap<String, Integer> hashMap = new HashMap<>();
        hashMap.put("Apple", 1);
        hashMap.put("Banana", 2);
        hashMap.put("Cherry", 3);

        TreeMap<String, Integer> treeMap = new TreeMap<>();
        treeMap.put("Apple", 1);
        treeMap.put("Banana", 2);
        treeMap.put("Cherry", 3);
    }
}

        在这个例子中,我们创建了不同类型的 List 和 Map 实例,并添加了一些元素。由于 List 和 Map 接口不保证元素的顺序,因此添加元素的顺序可能与打印顺序不同。


http://www.kler.cn/a/322411.html

相关文章:

  • 视频生成模型哪家强?豆包可灵通义海螺全面评测【AI评测】
  • StopWath,apache commons lang3 包下的一个任务执行时间监视器的使用
  • 起号半个月GMV 1300W+,视频号这个赛道真香!
  • CMU 10423 Generative AI:lec7、8、9(专题2:一张图理解diffusion model结构、代码实现和效果)
  • 论文阅读 | 一种基于潜在向量优化的可证明安全的图像隐写方法(TMM 2023)
  • 端上自动化测试平台实践
  • Go 实现:椭圆曲线数字签名算法ECDSA
  • 50道渗透测试面试题,全懂绝对是高手
  • 边裁员边收购,思科逐渐变身软件并购之王
  • Java 入门指南:并发设计模式 —— 两端终止模式
  • C++之STL—常用排序算法
  • JavaScript 操作 DOM元素CSS 样式的几种方法
  • MATLAB软件开发通用控制的软件架构参考
  • (JAVA)浅尝关于 “栈” 数据结构
  • Android 增加宏开关控制android.bp
  • MySQL查询语句优化
  • DataGrip远程连接Hive
  • Python中列表常用方法
  • C语言 15 预处理
  • vue3 TagInput 实现