LinkedList链表

List接口的链接列表实现。允许存储所有元素(包含null)。使用频繁增删元素。

linkedList方法:

void addFirst(E e) 指定元素插入列表的开头

void addLast(E e)

boolean offerFirst(E e) 在此列表的开头插入指定的元素

boolean offerLast(E e)

E getFirst() 返回此列表的第一个元素

E getLast()

E removeFirst() 移除并返回此列表的第一个元素

E removeLast()

E peekFirst() 获取但不移除此列表的一个元素,若此列表为空,则返回null

E peekLast()

E pollFirst() 获取并移除此列表的第一个元素,若此列表为空,则返回null

E pollLast()

LinkList线程不同步,可在创建时使其保持同步,

List list=Collections.synchronizedList(new LinkList(…));

示例:

package test;

import java.util.LinkedList;

import java.util.List;

public class LinkedListTest {

public static void main(String[] args) {

// 测试LinkedList常用方法

testLinkedListMethods() ;

}

private static void testLinkedListMethods() {

LinkedList<String> llist = new LinkedList<String>();

//List<String> llist = new LinkedList<String>();

llist.add("1");

llist.add("2");

llist.add("3");

llist.add("测试4");

llist.add(2, "test5");//添加到指定位置

llist.addFirst("开始位置6");//添加到开始位置

System.out.println("1-llist:"+llist);

System.out.println("2-llist.removeFirst():"+llist.removeFirst());//removeFirst()返回移除的值

System.out.println("3-llist:"+llist);

System.out.println("4-llist.getFirst():"+llist.getFirst());//,LinkedList有

llist.offerFirst("10");//列表开始位置插入,LinkedList有

System.out.println("5-llist:"+llist);

System.out.println("llist.pollFirst():"+llist.pollFirst());//返回并移除列表开始位置的值

System.out.println("6-llist:"+llist);

System.out.println("7-llist.peekFirst():"+llist.peekFirst());//返回但不移除列表第一个元素

llist.addLast("列表尾部插入1");//,LinkedList有

System.out.println("8-llist:"+llist);

System.out.println("9-llist.removeLast():"+llist.removeLast());//返回并移除列表最后一个值

System.out.println("10-llist:"+llist);

System.out.println("11-llist.getLast():"+llist.getLast());//返回列表最后一个值

llist.offerLast("20");//列表尾部增加

System.out.println("12-llist:"+llist);

System.out.println("13-llist.pollLast():"+llist.pollLast());//获取并移除列表的列表的最后一个元素

System.out.println("14-llist:"+llist);

System.out.println("15-llist.peekLast():"+llist.peekLast());//

llist.set(2, "300");

System.out.println("16-\nget(3):"+llist.get(2));

// 将LinkedList转行为数组

String[] arr = llist.toArray(new String[0]);

for (String str:arr)

System.out.println("17-str:"+str);

System.out.println("18-size:"+llist.size());

// 清空LinkedList

llist.clear();

// 判断LinkedList是否为空

System.out.println("19-isEmpty():"+llist.isEmpty()+"\n");

}

}

java集合之linkedList链表基础的更多相关文章

  1. java集合之ArrayList链表基础

    ArrayList可变数组 : arrayList继承AbstractList抽象类,实现list接口,底层基于数组实现.可存放null,除了非同步的之外,大致等同Vector.适用快速访问,复制.序 ...

  2. 【Java集合】LinkedList详解前篇

    [Java集合]LinkedList详解前篇 一.背景 最近在看一本<Redis深度历险>的书籍,书中第二节讲了Redis的5种数据结构,其中看到redis的list结构时,作者提到red ...

  3. Java 集合之LinkedList源码分析

    1.介绍 链表是数据结构中一种很重要的数据结构,一个链表含有一个或者多个节点,每个节点处理保存自己的信息之外还需要保存上一个节点以及下一个节点的指针信息.通过链表的表头就可以访问整个链表的信息.Jav ...

  4. Java集合干货——LinkedList源码分析

    前言 在上篇文章中我们对ArrayList对了详细的分析,今天我们来说一说LinkedList.他们之间有什么区别呢?最大的区别就是底层数据结构的实现不一样,ArrayList是数组实现的(具体看上一 ...

  5. Java集合:LinkedList源码解析

    Java集合---LinkedList源码解析   一.源码解析1. LinkedList类定义2.LinkedList数据结构原理3.私有属性4.构造方法5.元素添加add()及原理6.删除数据re ...

  6. 死磕 java集合之LinkedList源码分析

    问题 (1)LinkedList只是一个List吗? (2)LinkedList还有其它什么特性吗? (3)LinkedList为啥经常拿出来跟ArrayList比较? (4)我为什么把LinkedL ...

  7. Java集合之LinkedList源码分析

    概述 LinkedLIst和ArrayLIst一样, 都实现了List接口, 但其内部的数据结构不同, LinkedList是基于链表实现的(从名字也能看出来), 随机访问效率要比ArrayList差 ...

  8. Java学习之集合(LinkedList链表集合)

    一.什么是链表集合,通过图形来看,比如33只知道它下一个是55 如果:现在要删除33的话,就是把55赋值给45,这样看它操作集合速度会非常快. 二.LinkedList特有方法 1.添加 addFir ...

  9. Java集合(五)--LinkedList源码解读

    首先看一下LinkedList基本源码,基于jdk1.8 public class LinkedList<E> extends AbstractSequentialList<E> ...

随机推荐

  1. [kuangbin带你飞]专题一 简单搜索 题解报告

    又重头开始刷kuangbin,有些题用了和以前不一样的思路解决.全部题解如下 点击每道题的标题即可跳转至VJ题目页面. A-棋盘问题 棋子不能摆在相同行和相同列,所以我们可以依此枚举每一行,然后标记每 ...

  2. 创建型模式总结(2.x)

    顾名思义,创建型模式的聚焦点在如何创建对象能够将对象的创建与使用最大化的分离从而降低系统的耦合度. 创建型模式可分为: 单例模式:一个类只能有一个实例对象 工厂模式: 简单工厂模式:聚焦单个产品种类的 ...

  3. 是的,是你的BFC - CSS中常用

    是的,是你的BFC - CSS中常用     是的,是你的BFC - CSS中常用 CFC 全称:(Block Formatting Contexts)含义是块级格式化上下文),就是一个块级元素的渲染 ...

  4. HTML文档简介

    HTML简介 HTML标签 html文档标签: html源代码就好像word文档,有特殊的语法结构定义自己的功能. html文档标签 html标签,其下由两个主要节点标签head.body. head ...

  5. Mysql 笔记(一)

    InnoDB存储引擎 mysql 存储引擎(好难用,看https://www.zybuluo.com/eqyun/note/27850) 简介 InnoDB是事务安全的MySQL存储引擎,从MySQL ...

  6. electron教程(二): http服务器, ws服务器, 进程管理

    我的electron教程系列 electron教程(一): electron的安装和项目的创建 electron教程(二): http服务器, ws服务器, 进程管理 electron教程(三): 使 ...

  7. JVM调优—Jstack

    Java命令学习系列(二)——Jstack   jstack是java虚拟机自带的一种堆栈跟踪工具. 功能 jstack用于生成java虚拟机当前时刻的线程快照.线程快照是当前java虚拟机内每一条线 ...

  8. 【转+】python为什么推荐使用多进程

    最近在看Python的多线程,经常我们会听到老手说:“Python下多线程是鸡肋,推荐使用多进程!”,但是为什么这么说呢?                要知其然,更要知其所以然.所以有了下面的深入研 ...

  9. 【ASP.NET 基础】WCF入门教程一(什么是WCF)?

    一.概述 Windows Communication Foundation(WCF)是由微软发展的一组数据通信的应用程序开发接口,可以翻译为Windows通讯接口,它是.NET框架的一部分.由 .NE ...

  10. IntelliJ IDEA 如何在同一个窗口创建多个项目--超详细教程

    一.IntelliJ IDEA与Eclipse的区别 二.在同一个窗口创建多个项目 1.打开IntelliJ IDEA,点击Create New Project 2.Java Enterprise-- ...