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效率要更高。但是按照对象进行移除时,两种方法效率都不高。