【Java】ArrayList集合

ArrayList是Java的一种集合类,基于数组实现,支持动态扩容。它可以存储任意类型对象,提供add(),remove(),get(),size()等操作。LinkedList作为对比,其增删操作更高效,但查找和修改较慢,适合链表操作。
摘要由CSDN通过智能技术生成

ArrayList详解

ArrayList是Java中的一个集合类,它是通过数组实现的动态数组。ArrayList可以存储任意类型的对象,具有自动扩容的功能,并且支持添加、删除、查找、修改等操作。其中,嵌套ArrayList也可以通过在ArrayList中储存ArrayList来实现。在使用时,可使用add()方法来添加元素,remove()方法来删除元素,get()方法来获取元素,size()方法来获取元素个数等方法来对ArrayList进行操作。
7
1、add( )方法
将元素插入到指定位置的集合中

 
import java.util.ArrayList;
 
public class Demo1{
    public static void main(String[] args) {
        ArrayList list = new ArrayList();
        list.add("张三");
        list.add("李四");
        list.add("王五");
        for (int i = 0; i < list.size(); i++) {
            System.out.println(list.get(i));
        }
    }
}

张三
李四
王五

2、 remove() 方法
删除集合中的单个元素。要注意这里删除的是第二个元素。

import java.util.ArrayList;
 
public class Demo2 {
    public static void main(String[] args) {
        ArrayList<String> s = new ArrayList<String>();
        s.add("zhangsan");
        s.add("lisi");
        s.add("wangwu");
        s.remove(1); 
        for (int i = 0; i < s.size(); i++) {
            System.out.println(s.get(i));}
    }
}

zhangsan
wangwu

这两个方法中也体现了get( )方法和size( )方法。另外常用的还有clear( )方法(删除集合中所有元素),sort( )方法(对元素进行排序)等等。

在书上还看到了一个LinkedList类,与 ArrayList 相比,LinkedList 的增加和删除的操作效率更高,而查找和修改的操作效率较低。因为LinkedList可以看作一个双向链表,而ArrayList底层是数组。

书上也给出了代码样例,来测试ArrayList和LinkedList分别按照索引和对象在增加和移除上耗时的差距。我们来实现一下:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

但是结果出现了异常,NumberFormatException异常,查询得这个异常表示在将字符串转换为数字时发生了错误,通常是由于字符串不是一个合法的数字格式引起的。
在这里插入图片描述
书上也给了结果,从结果上可以看出ArrayList和LinkedLIst在新增上速度差不多,如果对列表两端进行操作,LinkedList要快得多,如果对列表中间部分按照索引进行操作,ArrayList效率要更高。但是按照对象进行移除时,两种方法效率都不高。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值