再学Java基础——List集合

2024-05-08 11:52
文章标签 java list 再学 集合 基础

本文主要是介绍再学Java基础——List集合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

List、Set和Map是Java中常用的三种集合类型,它们各自具有不同的特点和用途。

  1. List(列表):
    • 特点:
      • 有序性:List中的元素是有序排列的,可以根据其索引值来访问对应位置的元素。
      • 重复性:List可以包含重复的元素。
      • 可变性:List是Java中一种可变的数据类型,可以添加、删除或修改其中的元素。
      • 可以包含不同类型的元素:List中的元素可以是任何数据类型,包括数字、字符串、对象等。
    • 用途:List通常用于存储需要保持插入顺序的元素,或者需要频繁访问特定位置的元素。
  2. Set(集合):
    • 特点:
      • 无序性:Set中的元素没有顺序,无法通过索引来访问。
      • 唯一性:Set中不允许有重复的元素,每个元素在集合中只能出现一次。
      • 内部实现:Set内部通常是基于哈希表或平衡树等数据结构实现的。
      • 可用于去重和快速查找:由于Set中的元素是唯一的,所以可以方便地用于去重操作。同时,由于内部实现采用哈希表或树形结构,查找某个元素的时间复杂度为O(1)或O(log n)。
      • 元素必须是可哈希的:Set中的元素必须是可哈希的,即元素必须有一个明确的哈希值。
    • 用途:Set通常用于存储不需要保持插入顺序且不允许重复的元素。
  3. Map(映射):
    • 特点:
      • 键值对存储:Map中存储的元素是以键值对的形式保存的,每个键值对包含一个键对象和一个值对象。
      • 键的唯一性:在Map中,每个键对象是唯一的,不能存在相同的键对象。如果向Map中添加一个已经存在的键对象,则会替换掉原有的值对象。
      • 支持null键和null值(部分实现):某些Map实现(如HashMap和Hashtable)支持null键和null值,但其他实现(如TreeMap和ConcurrentHashMap)可能不允许有null键。
      • 无序性(部分实现):HashMap和Hashtable等散列表实现的Map在存储键值对时并不是以顺序方式存储的,因此不能保证元素的顺序。但如果使用LinkedHashMap,则可以按照插入顺序或访问顺序进行遍历。
      • 高效性:Map集合可以存储任意类型的键和值,如基本数据类型、自定义对象等。
    • 用途:Map通常用于存储具有唯一键的关联数组,其中键用于唯一标识值。

总结来说,List、Set和Map在Java中各自具有不同的特点和用途。List适用于需要保持插入顺序或频繁访问特定位置元素的场景;Set适用于需要存储唯一元素且不关心插入顺序的场景;而Map则适用于需要存储具有唯一键的关联数组的场景。

这篇关于再学Java基础——List集合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/970246

相关文章

测试服务搭建之centos7下安装java

一 安装Java 1 创建普通用户 useradd userNameTest passwd userNameTest 提示输入密码:【输入wujian的密码】 user:userNameTest group:root passwd:123456789   2 给“userNameTest”分配root权限 vi /etc/sudoers 在文件中找到 # %wheel ALL=(

selenium +java 多个类公用driver问题

问题点:太久没有写selenium代码,居然把driver公用的问题忘记了,即:每写一个测试类,执行过程中都会新建一个窗口,这样应该说是非常不专业的。 大概想了一个方法,虽然看起来也不怎么专业,但感觉能用就很开心了。 解决步骤:                1 创建一个获取获取driver的方法getDriver()                2 创建成员变量,将 getDriver()赋值

mybaits基础增删改查-------mybatis(四)

Mybatis的增删改查 mybatis流程: 1 创建实体类及接口方法 2 创建全局配置文件 configuration.xml 3 创建 sql 映射文件 BlogMapper.xml 4 将全局文件中维护 sql映射文件配置 5 调用java API 执行相关sql操作 注意sqlSession是线程非安全的 实体java类: package model;public class Blo

IDEA +maven git tomcat database数据库 调试 插件 log4j Spring junit

前言 idea优化配置、常规配置、配置maven、git、tomcat、database数据库、调试配置、插件配置、log4j配置、Spring配置等等,稍后一一更新! 优化配置(#item1 “item1”) 打开文件 :“idea – > bin – >idea64.exe.vmoptions” -Xms: 初始内存;-Xmx : 最大内存;-ReservedCodeCache

sort常用排序模式---------shell基础篇(三)

sort 排序命令使用 表达式意义sort -c test测试文件“test”是否已经经过排序,一般用处不大sort -k1 test.txt按照第1域对文件test.txt进行排序,日常可以用来对合并的日志文件进行时间排序sort -k1 -m log1.txt log2.txt按照第一域进行排序后合并输出到控制台,建议使用“>>” 将合并内容输出到另一个文件中sort -t / -k3 te

4-Springboot集成FLOWABLE之流程驳回

目录标题 演示地址效果功能后端代码补充 演示地址 效果 功能 默认驳回到上一节点 后端代码 flowable自带驳回功能, 在源码ProcessInstanceResource.class下已有该功能,不需要自己额外去写 @ApiOperation(value = "Change the state a process instance", tags = { "Pr

bimface 模型集成-后端(java)上传、发起转换、获取转换状态

目录 前言后端架构流程存储表结构全局工具类先根据appid, appsecret 生成accesstoken, 保存到自己的存储服务器。利用保存的 accesstoken 上传模型发起转换获取转换状态根据bimface文件ID获取模型viewtoken, 获取到viewtoken就可以利用前端浏览模型或图纸了 前言 之前没有注意官方有个sdk,然后自己就实现了这么个逻辑。建议

JavaScript的变量申明提前

变量提升 JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部: 只是将变量的申明提前,而不提前变量的值和函数的值 'use strict';function foo() {var x = 'Hello, ' + y;alert(x);var y = 'Bob';}foo(); 虽然是strict模式,但语句var x = 'Hell

Java ArryList

ArrayList简介 ArrayList就是传说中的动态数组,用MSDN中的说法,就是Array的复杂版本,它提供了如下一些好处: 1、动态的增加和减少元素; 2、实现了ICollection和IList接口 ; 3、灵活的设置数组的大小; ArrayList的基本用法 1、创建一个动态数组,并赋值 //创建一个动态数组ArrayList list = new ArrayL

SpringBoot 学习六:数据库的增删改查

1、新建一个Girl类,添加如下代码: package controlle;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.Id;@Entitypublic class Girl {@Id@GeneratedValueprivate Integer