Java中的数组和集合

这篇具有很好参考价值的文章主要介绍了Java中的数组和集合。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数组

Java 中的数组是一种容器,可以用来存储一组相同类型的元素。数组可以是一维的,也可以是多维的。

一维数组

使用示例

一维数组是指只有一行的数组。在Java中,定义方式如下:

int[] array = new int[5];

这创建了一个名为 array 的整型数组,该数组有 5 个元素。可以使用下标访问数组中的元素,例如:array[0] 表示第一个元素,array[1] 表示第二个元素,以此类推。数组下标从 0 开始,因此最后一个元素的下标是 array.length - 1。

对于一维数组,可以使用循环语句轻松遍历所有元素。例如,以下代码打印了上述数组中的所有元素:

for (int i = 0; i < array.length; i++) {
    System.out.println(array[i]);
}

注意事项

  • 数组的长度是不可变的,所以在定义数组时必须指定数组长度。
  • 数组下标从 0 开始,最大下标为数组长度减一。
  • 访问数组时要确保下标不越界,否则会导致数组越界异常。

多维数组

使用示例

多维数组是指包含多行和多列的数组。在Java中,我们可以使用以下方式定义一个二维数组:

int[][] array = new int[3][4];

这将创建一个名为 array 的二维整型数组,该数组有 3 行 4 列。可以使用两个下标来访问二维数组中的元素,例如:array[0][0] 表示第一行第一列的元素,array[1][2] 表示第二行第三列的元素,以此类推。

对于多维数组,通常需要使用嵌套循环来访问所有元素。例如,以下代码打印了上述二维数组中的所有元素:

for (int i = 0; i < array.length; i++) {
    for (int j = 0; j < array[i].length; j++) {
        System.out.println(array[i][j]);
    }
}

注意事项

  • 定义二维数组时,需要指定行数和列数。
  • 可以将二维数组看作是一个矩阵,其中第一个下标表示行数,第二个下标表示列数。
  • 访问数组元素时要确保下标不越界,否则会导致数组越界异常。

总之,在Java中使用数组和集合时,要注意正确的使用方式以及各自的特点和限制,尽量避免出现不必要的性能和安全问题。

集合

Java 中的集合是一组对象的容器,可以用来存储和操作各种类型的数据。Java 提供了许多集合实现,包括 List、Set、Queue 和 Map 等。下面我们将重点介绍 List、Set 和 Map。

List

List是一个有序可重复的集合,可以根据元素的位置(下标)来进行操作。常用的实现类包括:

  • ArrayList:基于数组实现,支持快速随机访问,但插入和删除操作比较慢。
  • LinkedList:基于链表实现,支持快速插入和删除,但访问元素比较慢。
  • Vector:线程安全的动态数组,性能较差,已经被ArrayList替代。
  • List 是一种有序的容器,它可以包含重复元素。在 Java 中,最常见的 List 实现是 ArrayList 和 LinkedList。

ArrayList

ArrayList 是基于数组实现的动态数组,它可以自动扩展容量来容纳新元素。以下是如何使用 ArrayList 的示例代码:

ArrayList<Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(2);
list.add(3);
int size = list.size();
int element = list.get(0);
list.remove(1);
list.clear();

在上面的示例中,我们首先创建了一个整型 ArrayList,然后添加了三个元素。可以通过 size() 方法获取 ArrayList 的大小,通过 get(index) 方法获取特定索引处的元素,通过 remove(index) 方法删除特定索引处的元素,通过 clear() 方法清空列表。

ArrayList是一个基于动态数组实现的List,使用数组来保存元素,具有以下特点:

  • 支持随机访问,时间复杂度为O(1)
  • 插入和删除操作的效率较低,时间复杂度为O(n)
  • 不支持线程同步,因此不是线程安全的
  • ArrayList适用于需要随机访问元素,但是插入和删除操作相对较少的场景。

LinkedList

LinkedList 是基于链表实现的集合,它可以在任意位置进行插入和删除操作。以下是如何使用 LinkedList 的示例代码:

LinkedList<Integer> list = new LinkedList<Integer>();
list.add(1);
list.add(2);
list.add(3);
int size = list.size();
int element = list.get(0);
list.addFirst(0);
list.addLast(4);
list.remove(1);
list.clear();

在上面的示例中,我们首先创建了一个整型 LinkedList,然后添加了三个元素。可以通过 size() 方法获取 LinkedList 的大小,通过 get(index) 方法获取特定索引处的元素,通过 addFirst(element) 和 addLast(element) 方法在列表头部或尾部添加元素,通过 remove(index) 方法删除特定索引处的元素,通过 clear() 方法清空列表。

LinkedList是一个双向链表实现的List,每个节点都存储下一个节点和上一个节点的引用,具有以下特点:

  • 支持快速的插入和删除操作,时间复杂度为O(1)
  • 访问元素速度较慢,时间复杂度为O(n)
  • 不支持线程同步,因此不是线程安全的
  • LinkedList适用于需要频繁插入和删除元素的场景。

Set

Set是一个无序不可重复的集合,常用的实现类包括:

  • HashSet:基于哈希表实现,插入和删除元素速度很快,但是不能保证顺序。
  • TreeSet:基于红黑树实现,有序的Set,但是性能相对较差。
  • LinkedHashSet:基于哈希表和链表实现,在HashSet的基础上记录了元素插入的顺序。

HashSet

HashSet 是基于哈希表实现的集合,它不保证元素的顺序,并且可以很快地查找元素。以下是如何使用 HashSet 的示例代码:

HashSet<Integer> set = new HashSet<Integer>();
set.add(1);
set.add(2);
set.add(3);
int size = set.size();
boolean contains = set.contains(1);
set.remove(2);
set.clear();

在上面的示例中,我们首先创建了一个整型 HashSet,然后添加了三个元素。可以通过 size() 方法获取 HashSet 的大小,通过 contains(element) 方法检查 HashSet 是否包含特定元素,通过 remove(element) 方法删除特定元素,通过 clear() 方法清空集合。

HashSet是一个基于哈希表实现的Set,使用哈希表来保存元素,具有以下特点:

  • 插入、删除、查询等操作的效率都非常高,时间复杂度为O(1)
  • 元素的顺序不确定
  • 不支持线程同步,因此不是线程安全的
    HashSet适用于判断元素是否存在,或者需要快速添加、删除元素的场景。

TreeSet

TreeSet 是基于红黑树实现的集合,它保证元素按照自然顺序或者给定的比较器进行排序。以下是如何使用 TreeSet 的示例代码:

TreeSet<Integer> set = new TreeSet<Integer>();
set.add(3);
set.add(1);
set.add(2);
int size = set.size();
set.remove(2);
set.clear();

在上面的示例中,我们首先创建了一个整型 TreeSet,然后添加了三个元素。可以通过 size() 方法获取 TreeSet 的大小,通过 remove(element) 方法删除特定元素,通过 clear() 方法清空集合。

Map

Map是一种键值对存储结构,每个键只能对应一个值。常用的实现类包括:

  • HashMap:基于哈希表实现,插入和删除元素速度很快,但是不能保证顺序。
  • TreeMap:基于红黑树实现,有序的Map,但是性能相对较差。
  • LinkedHashMap:基于哈希表和链表实现,在HashMap的基础上记录了元素插入的顺序。

HashMap

HashMap 是基于哈希表实现的 Map,它不保证键值对的顺序。以下是如何使用 HashMap 的示例代码:

TreeSet<Integer> set = new TreeSet<Integer>();
set.add(3);
set.add(1);
set.add(2);
int size = set.size();
set.remove(2);
set.clear();

在上面的示例中,我们首先创建了一个键为字符串、值为整型的 HashMap,然后添加了三个键值对。可以通过 size() 方法获取 HashMap 的大小,通过 containsKey(key) 方法检查 HashMap 是否包含特定键,通过 get(key) 方法获取特定键对应的值,通过 remove(key) 方法删除特定键值对,通过 clear() 方法清空 Map。

TreeMap

TreeMap 是基于红黑树实现的 Map,它保证键值对按照键的自然顺序或者给定的比较器进行排序。以下是如何使用 TreeMap 的示例代码:

TreeMap<String, Integer> map = new TreeMap<String, Integer>();
map.put("c", 3);
map.put("a", 1);
map.put("b", 2);
int size = map.size();
int value = map.get("b");
map.remove("c");
map.clear();

在上面的示例中,我们首先创建了一个键为字符串、值为整型的 TreeMap,然后添加了三个键值对。可以通过 size() 方法获取 TreeMap 的大小,通过 get(key) 方法获取特定键对应的值,通过 remove(key) 方法删除特定键值对,通过 clear() 方法清空 Map。

TreeMap是一个基于红黑树实现的Map,使用红黑树来保存元素,具有以下特点:

  • 插入、删除、查询等操作的效率都较高,时间复杂度为O(log n)
  • 元素按照键值升序排序
  • 不支持线程同步,因此不是线程安全的
  • TreeMap适用于需要按照键值排序,或者需要快速添加、删除元素的场景。

除了以上常用的集合实现,Java还提供了一些其他的集合类,例如Stack、Queue等。在使用集合时,需要根据具体的情况选择合适的实现类,并注意其特性和使用方法。

总结

Java 中提供了丰富的数组和集合类型,可以用来存储和操作各种类型的数据。了解这些类型的区别和使用场景,可以帮助我们更加高效地编写Java程序。在使用数组和集合时,我们还应该注意内存占用和性能等方面的问题,避免出现不必要的性能瓶颈。文章来源地址https://www.toymoban.com/news/detail-497812.html

到了这里,关于Java中的数组和集合的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java集合与数组互相转换

            集合与数组互相转换在日常业务开发中必不可少,有时业务需要的是集合,而程序提供的是数组;或者业务需要的是数组,而程序提供的是集合,这就需要转换了。 以下简单提供几种常用的方法(以Int作为泛型示例),记录一下方便查阅! 推荐方式一 推荐方式一

    2024年02月11日
    浏览(51)
  • 安全无忧:Java并发集合容器的应用与实践

    JDK 提供的这些容器大部分在 java.util.concurrent 包中: ConcurrentHashMap : 线程安全的 HashMap CopyOnWriteArrayList : 线程安全的 List,在读多写少的场合性能非常好,远远好于 Vector ConcurrentLinkedQueue : 高效的并发队列,使用链表实现。可以看做一个线程安全的 LinkedList,这是一个非阻塞队列

    2024年01月19日
    浏览(42)
  • 【Java集合与数组】List<T>数组和数组List<T>的区别(124)

    List数组 :存储List的数组,即:数组中的元素是:List; 数组List :存储数组的List,即:List中的数据是类型的数组; 测试案例: 测试输出:

    2024年02月11日
    浏览(43)
  • 程序人生——Java数组和集合使用建议(2)

    程序人生——Java数组和集合使用建议(2) 需求:要删除一个ArrayList中的20-30范围内的元素;将原列表转换为一个可变列表,然后使用subList获取到原列表20到30范围内的一个视图(View),然后清空该视图内的元素,即可在原列表中删除20到30范围内的元素 建议72:生成子列表后

    2024年03月19日
    浏览(47)
  • springboot读取yml文件中的list列表、数组、map集合和对象方法实例

    目录前言application.yml定义list集合application.yml定义数组类型总结 前言 springboot配置文件yml类型简单的风格,十分受大家的欢迎,支持字符string类型,支持列表list类型,支持集合map类型,支持数组array类型,支持类对象类型,下面我们来实战下这些形式的配置如何取值 applicatio

    2024年02月09日
    浏览(49)
  • #java 逗号分隔String字符串 - 数组 - 集合,相互转换

    1. 准备一个逗号分割字符串 2. 逗号分割字符串转换为集合(转换为集合之前会先转换为数组) 3. 集合转换为逗号分隔的字符串 4. 数组转逗号分隔字符串

    2024年02月04日
    浏览(51)
  • 探索C++中的动态数组:实现自己的Vector容器

    🎉个人名片 : 🐼作者简介:一名乐于分享在学习道路上收获的大二在校生 🙈个人主页🎉:GOTXX 🐼个人WeChat:ILXOXVJE 🐼本文由GOTXX原创,首发CSDN🎉🎉🎉 🐵系列专栏:零基础学习C语言----- 数据结构的学习之路----C++的学习之路 🐓每日一句:如果没有特别幸运,那就请特

    2024年03月16日
    浏览(45)
  • 【Java】集合List转换为数组【toArray() /stream()流】实现

    在Java中,集合(List 接口的实现类)提供了一个名为 toArray 的方法,用于将集合中的元素转换成数组。该方法有两个主要的重载形式,分别用于不同的情况。 这个方法将集合中的元素复制到一个指定类型的数组中,并返回该数组。 如果指定的数组大小足够容纳集合中的所有

    2024年02月03日
    浏览(43)
  • 【JavaSE专栏48】Java集合类ArrayList解析,这个动态数组数据结构你了解吗?

    作者主页 :Designer 小郑 作者简介 :3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN学院、蓝桥云课认证讲师。 主打方向 :Vue、SpringBoot、微信小程序 本文讲解了 Java 中集合类 ArrayList 的语法、使用说明和应用场景,并给出了样例代码。

    2024年02月16日
    浏览(59)
  • Java中的集合类

    一. 介绍 在Java中,集合是一种用于存储和操作多个元素的容器。它更方便地操作和管理一组对象,集合类提供了比传统的数组更强大和灵活的功能,可以动态地添加、删除和查找元素,以及进行排序、过滤等操作。集合类有一个共同特点,就是它们只容纳对象,如果想在集合

    2024年02月16日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包