博客
关于我
java LinkedList
阅读量:369 次
发布时间:2019-03-04

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

  • LinkedList实现了双向链表和双端队列特点
  • 可以添加任意元素(元素可以重复),包括null
  • 线程不安全,没有实现同步
  • LinkedList底层维护了一个双向链表
  • LinkedList中维护了两个属性firstlast分别指向首节点尾节点
  • 每个节点(Node对象),里面又维护了prev,next,item三个属性,其中通过prev指向前一个,通过next指向后一个节点,最终实现双向链表
  • 所以LinkedList的元素的添加和删除,不是通过数组完成的,相对效率较高
public class LinkedListDemo01 {       public static void main(String[] args) {           // 模拟一个简单的双向链表        Node jack = new Node("jack");        Node tom = new Node("tom");        Node ll = new Node("ll");        // 连接三个节点, 形成双向链表        // jack => tom => ll        jack.next = tom;        tom.next = ll;        // ll => tom => jack        ll.prev = tom;        tom.prev = jack;        // 让first引用指向jack,也就是双向链表的首节点        Node first = jack;        // 让last引用指向ll,也就是双向链表的尾结点        Node last = ll;        // 演示从头到尾进行遍历        while (true) {               if (first == null) {                   break;            }            //输出first信息            System.out.println(first);            first = first.next;        }        System.out.println("=========");        // 从尾到头遍历        while (true) {               if (last == null) {                   break;            }            // 输出end信息            System.out.println(last);            last = last.prev;        }        System.out.println("=========");        // 演示链表添加对象/数据,是多么快速方便        // 要求在 tom和ll之间,插入一个对象java        // 1.创建对象        Node java = new Node("java");        // jack => tom => ll        java.prev = tom;        java.next = ll;        ll.prev = java;        tom.next = java;        // 让first引用指向jack,也就是双向链表的首节点        first = jack;        // 演示从头到尾进行遍历        while (true) {               if (first == null) {                   break;            }            //输出first信息            System.out.println(first);            first = first.next;        }    }}// 定义一个Node类, Node对象表示双向链表的一个节点class Node {       /**     * 真正存放数据     */    public Object item;    /**     * 指向下一个节点     */    public Node next;    /**     * 指向上一个节点     */    public Node prev;    public Node(Object item) {           this.item = item;    }    @Override    public String toString() {           return "Node name = " + item;    }}

转载地址:http://ihce.baihongyu.com/

你可能感兴趣的文章
MySQL命令行登陆,远程登陆MySQL
查看>>
mysql命令:set sql_log_bin=on/off
查看>>
mySQL和Hive的区别
查看>>
MySQL和Java数据类型对应
查看>>
mysql和oorcale日期区间查询【含左右区间问题】
查看>>
MYSQL和ORACLE的一些操作区别
查看>>
mysql和redis之间互相备份
查看>>
MySQL和SQL入门
查看>>
mysql在centos下用命令批量导入报错_Variable ‘character_set_client‘ can‘t be set to the value of ‘---linux工作笔记042
查看>>
Mysql在Linux运行时新增配置文件提示:World-wrirable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored 权限过高导致
查看>>
Mysql在Windows上离线安装与配置
查看>>
MySQL在渗透测试中的应用
查看>>
Mysql在离线安装时启动失败:mysql服务无法启动,服务没有报告任何错误
查看>>
Mysql在离线安装时提示:error: Found option without preceding group in config file
查看>>
MySQL基于SSL的主从复制
查看>>
Mysql基本操作
查看>>
mysql基本操作
查看>>
mysql基本知识点梳理和查询优化
查看>>
mysql基础
查看>>
Mysql基础 —— 数据基础操作
查看>>