博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java List操作
阅读量:5011 次
发布时间:2019-06-12

本文共 3957 字,大约阅读时间需要 13 分钟。

 

一、List:、有顺序以线性方式存储,可以存放重复对象

线程安全方法:List list = Collections.synchronizedList(new LinkedList(...));

LinkedList:双向链表实现存储  索引数据慢插入数度较快  线程不安全(比安全性能好)

ArrayList:数组方式存储数据  索引数据快插入数据慢  线程不安全

Vector:数组方式存储数据  索引数据快插入数据慢  线程安全

Stack:继承自Vector,实现一个后进先出的堆栈

ArrayList:

import java.util.ArrayList;import java.util.List;public class Main {    public static void main(String[] args) {        List books = new ArrayList();        //向books集合中添加三个元素        books.add(new String("11111111111"));        books.add(new String("22222222222"));        books.add(new String("33333333333"));        System.out.println(books);        //将新字符串对象插入在第二个位置        books.add(1 , new String("44444444444"));        for (int i = 0 ; i < books.size() ; i++ )        {            System.out.println(books.get(i));        }        //删除第三个元素        books.remove(2);        System.out.println(books);        //判断指定元素在List集合中位置:输出1,表明位于第二位        System.out.println(books.indexOf(new String("44444444444")));  //①        //将第二个元素替换成新的字符串对象        books.set(1, new String("LittleHann"));        System.out.println(books);        //将books集合的第二个元素(包括)        //到第三个元素(不包括)截取成子集合        System.out.println(books.subList(1 , 2));    }}

Result:

[11111111111, 22222222222, 33333333333]11111111111444444444442222222222233333333333[11111111111, 44444444444, 33333333333]1[11111111111, LittleHann, 33333333333][LittleHann]
View Code

Stack:

import java.util.Stack;public class Main {    public static void main(String[] args) {        Stack v = new Stack();        //依次将三个元素push入"栈"        v.push("11");        v.push("22");        v.push("33");        System.out.println(v);        //访问第一个元素,但并不将其pop出"栈"        System.out.println(v.peek());        System.out.println(v);        //pop出第一个元素        System.out.println(v.pop());        System.out.println(v);    }}

Result:

[11, 22, 33]33[11, 22, 33]33[11, 22]
View Code

LinkedList:

import java.util.LinkedList;public class Main {    public static void main(String[] args) {        LinkedList books = new LinkedList();                //将字符串元素加入队列的尾部(双端队列)        books.offer("11");        //将一个字符串元素加入栈的顶部(双端队列)        books.push("22");        //将字符串元素添加到队列的头(相当于栈的顶部)        books.offerFirst("33");        System.out.println(books);        //访问、并不删除栈顶的元素        System.out.println(books.peekFirst());        //访问、并不删除队列的最后一个元素        System.out.println(books.peekLast());        //将栈顶的元素弹出"栈"        System.out.println(books.pop());        //下面输出将看到队列中第一个元素被删除        System.out.println(books);        //访问、并删除队列的最后一个元素        System.out.println(books.pollLast());        //下面输出将看到队列中只剩下中间一个元素:        System.out.println(books);    }}

Result:

[33, 22, 11]331133[22, 11]11[22]
View Code

PriorityQueue:

PriorityQueue pq = new PriorityQueue();        //下面代码依次向pq中加入四个元素        pq.offer(6);        pq.offer(-3);        pq.offer(9);        pq.offer(0);        //输出pq队列,并不是按元素的加入顺序排列,        //而是按元素的大小顺序排列,输出[-3, 0, 9, 6]        System.out.println(pq);        //访问队列第一个元素,其实就是队列中最小的元素:-3        System.out.println(pq.poll());

Result:

[-3, 0, 9, 6]-3
View Code

PriorityQueue不允许插入null元素,它还需要对队列元素进行排序

ArrayDeque:

import java.util.ArrayDeque;public class Main {    public static void main(String[] args) {        ArrayDeque stack = new ArrayDeque();        //依次将三个元素push入"栈"        stack.push("11");        stack.push("22");        stack.push("33");        System.out.println(stack);        //访问第一个元素,但并不将其pop出"栈"        System.out.println(stack.peek());        System.out.println(stack);        //pop出第一个元素        System.out.println(stack.pop());        System.out.println(stack);    }}

结果:

[33, 22, 11]33[33, 22, 11]33[22, 11]
View Code

List集合类应用场景:

1. java提供的List就是一个"线性表接口",ArrayList(基于数组的线性表)、LinkedList(基于链的线性表)是线性表的两种典型实现2. Queue代表了队列,Deque代表了双端队列(既可以作为队列使用、也可以作为栈使用)3. 因为数组以一块连续内存来保存所有的数组元素,所以数组在随机访问时性能最好。所以的内部以数组作为底层实现的集合在随机访问时性能最好。4. 内部以链表作为底层实现的集合在执行插入、删除操作时有很好的性能5. 进行迭代操作时,以链表作为底层实现的集合比以数组作为底层实现的集合性能好

转载于:https://www.cnblogs.com/hongdada/p/6049907.html

你可能感兴趣的文章
获取NVIDIA显卡的温度
查看>>
Dijkstra算法
查看>>
Deep Learning 9: Performance
查看>>
面试题61 把二叉树打印成多行
查看>>
C#例子 易懂故事 接口 委托 事件 异步通知 好玩.
查看>>
[转]Windows Shell 编程 第十一章 【来源:http://blog.csdn.net/wangqiulin123456/article/details/7987992】...
查看>>
修改presto新版源码让他支持redash数据库
查看>>
Javascript的书写位置
查看>>
树-线索二叉树
查看>>
JAVA遇见HTML——Servlet篇:Servlet基础
查看>>
第二章 Vue快速入门--20 品牌案例-完成品牌列表的添加功能+ 21 品牌案例-根据Id完成品牌的删除...
查看>>
[转]CodeSmith和PowerDesigner的使用安装和数据库创建
查看>>
Android手机配置gcc,实现手机编译代码
查看>>
Java单例模式
查看>>
重温WCF之消息契约(MessageContract)(六)
查看>>
Excel2007制作直方图和正态分布曲线图
查看>>
android adb常用指令
查看>>
Android框架之路——GreenDao3.2.2的使用
查看>>
类方法WCF学习笔记-KnowTypeAttribute用法
查看>>
平台程序微信平台开发应用的签名
查看>>