一、定义

ArrayList和LinkedList是两个集合类,用于储存一系列的对象引用(references)。

引用的格式分别为:

ArrayList<String> list = new ArrayList<String>();

LinkedList<Integer> list = new LinkedList<Integer>();

二、ArrayList与LinkedList的大致区别

1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构;

2.对于随机访问get和set,ArrayList优先于LinkedList。因为LinkedList要移动指针。

3.对于新增和删除操作(add和remove),LinkedList比较占优势,因为ArrayList要移动数据。

(关于3,网上又争论,意思是说对大型数据的增删,收尾增删或对中间某位作用,效果是不同的,有待考证!)

三、ArrayList与LinkedList常用方法

代码实例:

 import java.util.ArrayList;

 public class CollT2 {

     public static void main(String[] args) {

         // 新建一个ArrayList
ArrayList<String> list = new ArrayList<String>();
System.out.println("初始化大小:" + list.size()); // 添加元素
list.add("北京");
list.add("天津");
list.add("上海");
list.add("广州");
list.add("深圳");
list.add("海口");
list.add("厦门");
System.out.println("当前容量:" + list.size()); // 讲ArrayList的大小和实际所含元素的大小设置一致
// 注意:此操作演示下面会抛出的异常:java.util.ConcurrentModificationException
list.trimToSize(); // 遍历
for (String string : list) {
System.out.println(string); // 在指定位置插入元素
list.add(2, "黑龙江");
for (String string1 : list) {
System.out.println(string1);
}
System.out.println("=======分割线========"); // 清空list
list.clear();
for (String string3 : list) {
System.out.println(string3);
} }
}
}

 import java.util.LinkedList;

 //ArrayList基于数组实现,所以它具备数组的特点,即查询速度较快,但是修改、插入的速度却有点儿慢。
//下面将要介绍的LinkedList就是来解决这个问题的,LinkedList基于链表,与ArrayList互补。
//所以实际开发中我们应该按照自己的需求来定到底用哪一个。 //LinkedList底层采用双向循环列表实现,进行插入和删除操作时具有较高的速度.
//我们还可以使用LinkedList来实现队列和栈 public class CollT3 {
@SuppressWarnings("null")
public static void main(String[] args) { // 創建一個list
LinkedList<Integer> list = new LinkedList<Integer>();
LinkedList<Integer> list2 = new LinkedList<Integer>();
LinkedList<Integer> list3 = new LinkedList<Integer>();
LinkedList<Integer> list4 = new LinkedList<Integer>(); System.out.println(list.size()); // 添加元素
// list.add("锅包肉");没考虑数据类型
// list.add("溜肉段");
System.out.println("====分割线1===="); list.add(5);
list.add(6);
list.add(7);
list.add(8);
list.add(9);
list.add(10); list2.add(-1);
list2.add(-2);
list2.add(-3);
list2.add(-4);
list2.add(-5); list3.add(111);
list3.add(222);
list3.add(333);
list3.add(444);
list3.add(555); list4=null; System.out.println(list.size()); // 遍历
for (Integer a : list) {
System.out.println(a);
} list.add(4, 11111);
System.out.println(list);// 竟然是横着打印出来的
System.out.println("===分割线2===="); list.add(3, 22222);
System.out.println(list);// 二次验证竟然是横着打印出来的 System.out.println("===分割线3====");
System.out.println(list.addAll(list2));
System.out.println(list); System.out.println("===分割线4====");
// 错误:System.out.println(2,list.addAll(list3));
list.addAll(2, list3);// 将指定 collection 中的所有元素从指定位置开始插入此列表。
System.out.println(list); System.out.println("===分割线5====");
list3.addFirst(3);//需要单独打印
System.out.println(list3); System.out.println("===分割线6====");
list3.addLast(0000000001);//
list3.addLast(000000000);//
list3.addLast(0);//0
//list3.addLast(00000000000000009);//The literal 00000000000000009 of type int is out of range
list3.addLast(0000000000000000000000000000000000007);//末尾只能写到7,8和9不行
System.out.println(list3); list.clear();
System.out.println(list);//[] System.out.println("===分割线7===="); list2.clone();//返回此 LinkedList的浅表副本。
System.out.println(list); System.out.println("===分割线8====");
//list3.contains(999999999);//呃,竟然不是这么验证的!!!!
System.out.println(list3.contains(999999999));// 如果此列表包含指定元素,则返回 true。 System.out.println("===分割线9====");
//list3.element();//呃,竟然不是这么验证的!!!!
System.out.println(list3.element());//获取但不移除此列表的头(第一个元素)。
System.out.println(list3);//验证上面的操作真的只是获取没有移除 System.out.println("===分割线10====");//注意上面对list3的操作,给它头位添加个3了
System.out.println(list3.get(2));// 返回此列表中指定位置处的元素。 System.out.println("===分割线11====");
System.out.println(list3.getFirst());//返回此列表的第一个元素。
System.out.println(list3.getLast());//返回此列表的最后一个元素。 System.out.println("===分割线12====");
System.out.println(list3.indexOf(333));//返回此列表中首次出现的指定元素的索引,如果此列表中不包含该元素,则返回 -1。
System.out.println(list3.indexOf(10)); System.out.println("===分割线13====");
list3.add(333);
list3.add(333);
list3.add(333);
System.out.println(list3);
System.out.println(list3.lastIndexOf(0));//返回此列表中最后出现的指定元素的索引,如果此列表中不包含该元素,则返回 -1。
System.out.println(list3.lastIndexOf(9));//-1 System.out.println("===分割线14====");
list3.offer(6);//将指定元素添加到此列表的末尾(最后一个元素)。
System.out.println(list3.offer(6));//true
System.out.println(list3); System.out.println("===分割线15====");
System.out.println(list3.peek());// 获取但不移除此列表的头(第一个元素)。 //peekFirst();获取但不移除此列表的最后一个元素;如果此列表为空,则返回 null。
//System.out.println(list4.peekFirst());上面list4定义为null,黄色报错。用了@SuppressWarnings("null")。验证:java.lang.NullPointerException
//System.out.println(list4.peekLast());java.lang.NullPointerException System.out.println("===分割线16====");
System.out.println(list3);
list3.poll();
System.out.println(list3); System.out.println("===分割线17====");
System.out.println(list3);
list3.toArray();//返回以适当顺序(从第一个元素到最后一个元素)包含此列表中所有元素的数组。
System.out.println(list3);
} }

打印结果:

0
====分割线1====
6
5
6
7
8
9
10
[5, 6, 7, 8, 11111, 9, 10]
===分割线2====
[5, 6, 7, 22222, 8, 11111, 9, 10]
===分割线3====
true
[5, 6, 7, 22222, 8, 11111, 9, 10, -1, -2, -3, -4, -5]
===分割线4====
[5, 6, 111, 222, 333, 444, 555, 7, 22222, 8, 11111, 9, 10, -1, -2, -3, -4, -5]
===分割线5====
[3, 111, 222, 333, 444, 555]
===分割线6====
[3, 111, 222, 333, 444, 555, 1, 0, 0, 7]
[]
===分割线7====
[]
===分割线8====
false
===分割线9====
3
[3, 111, 222, 333, 444, 555, 1, 0, 0, 7]
===分割线10====
222
===分割线11====
3
7
===分割线12====
3
-1
===分割线13====
[3, 111, 222, 333, 444, 555, 1, 0, 0, 7, 333, 333, 333]
8
-1
===分割线14====
true
[3, 111, 222, 333, 444, 555, 1, 0, 0, 7, 333, 333, 333, 6, 6]
===分割线15====
3
===分割线16====
[3, 111, 222, 333, 444, 555, 1, 0, 0, 7, 333, 333, 333, 6, 6]
[111, 222, 333, 444, 555, 1, 0, 0, 7, 333, 333, 333, 6, 6]
===分割线17====
[111, 222, 333, 444, 555, 1, 0, 0, 7, 333, 333, 333, 6, 6]
[111, 222, 333, 444, 555, 1, 0, 0, 7, 333, 333, 333, 6, 6]

Java基础——ArrayList与LinkedList(一)的更多相关文章

  1. Java基础-ArrayList和LinkedList的区别

    大致区别:  1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. 2.对于随机访问get和set,ArrayList觉得优于LinkedList,因为Lin ...

  2. Java基础——ArrayList与LinkedList(二)

    今天练习ArrayList与LinkedList,在网上看到有关它俩应用效率的题型.觉得很有价值,保留一下. import java.util.ArrayList; import java.util. ...

  3. JAVA基础:ArrayList和LinkedList区别

    1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. 2.对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList ...

  4. Java 集合 ArrayList和LinkedList的几种循环遍历方式及性能对比分析 [ 转载 ]

    Java 集合 ArrayList和LinkedList的几种循环遍历方式及性能对比分析 @author Trinea 原文链接:http://www.trinea.cn/android/arrayl ...

  5. Java中ArrayList与LinkedList的区别

    Java中ArrayList与LinkedList的区别 一般大家都知道ArrayList和LinkedList的区别: 1. ArrayList的实现是基于数组,LinkedList的实现是基于双向 ...

  6. Java中arraylist和linkedlist源代码分析与性能比較

    Java中arraylist和linkedlist源代码分析与性能比較 1,简单介绍 在java开发中比較经常使用的数据结构是arraylist和linkedlist,本文主要从源代码角度分析arra ...

  7. java中ArrayList 和 LinkedList 有什么区别

    转: java中ArrayList 和 LinkedList 有什么区别 ArrayList和LinkedList都实现了List接口,有以下的不同点:1.ArrayList是基于索引的数据接口,它的 ...

  8. Java基础——ArrayList

    Java基础--ArrayList 作用:提供一个可变长度的集合,底层实际上是一个可变长度的数组 格式:ArrayList <E> arr=new ArrayList<>(); ...

  9. Java中ArrayList和LinkedList差别

    一般大家都知道ArrayList和LinkedList的大致差别: 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构.  2.对于随机訪问get和set.A ...

随机推荐

  1. 探索基于.NET下实现一句话木马之ashx篇

    0x01 前言 在渗透测试的时候各种PHP版的一句话木马已经琳琅满目,而.NET平台下的一句话木马则百年不变,最常见的当属下面这句 笔者感觉有必要挖坑一下.NET平台里的一句话木马,经过一番摸索填坑终 ...

  2. C#为什么不能像C/C++一样的支持函数只读传参

    C#为什么不能像C/C++一样的支持函数只读传参? 这个问题其实问的人挺多的,我自己也经常想实现这个功能,但是发现总是那么的不尽人意. 有些人倒是给出了一下答案,但是都不能很好的解决像C/C++一样的 ...

  3. Entity Framework Core 生成跟踪列-阴影属性

    摘自:https://www.cnblogs.com/tdfblog/p/entity-framework-core-generate-tracking-columns.html Ef Core 官方 ...

  4. 36_并发编程-multiprocess模块

    仔细说来,multiprocess不是一个模块而是python中一个操作.管理进程的包. 之所以叫multi是取自multiple的多功能的意思,在这个包中几乎包含了和进程有关的所有子模块.由于提供的 ...

  5. 关于scanf、getchar、getch、getche缓冲区分析——C语言

    缓冲区 根据数据刷新的时机可以将缓冲区的类型分为:全缓冲.行缓冲.无缓冲 (注意:Windows下的输出设备没有缓冲区,意思是printf是无缓冲的,但是在Linux下printf就是行缓冲的,至于为 ...

  6. Fusioncharts的数字格式化

      1.     小数点位数格式化 <chart ... decimals='2' > Eg.数值12.432, 13.4 and 13,使用<chart ... decimals= ...

  7. select2插件使用小记2 - 多选联动 - 笔记

    这是select2插件使用的第二篇,可参考第一篇 select2插件使用小记.上一篇主要是关于基本的使用,这篇主要是关于多选,及联动的.侧重点不同. 效果图如下: 遵从W3C标准:结构.样式.行为.以 ...

  8. JavaScript getter和setter

    对象的属性是由属性名name,值key,和其他特性(可读写性 writable,可枚举性enumerable,可配置性configurable)组成的.从ES5开发,提供了getter和setter ...

  9. vue.js生命周期钩子函数及缓存

    在使用vue.js进行开发时,使用最多的就是created.mounted.activated. 由于有些情况下,我们需要复用某些组件,因此需要用到keep-alive. 当引入keep-alive时 ...

  10. JAVA实现微信支付V3

    喜欢的朋友可以关注下,粉丝也缺. 相信很多的码友在项目中都需要接入微信支付,虽说微信支付已成为一个普遍的现象,但是接入的过程中难免会遇到各种各样的坑,这一点支付宝的SDK就做的很好,已经完成的都知道了 ...