博客
关于我
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/

你可能感兴趣的文章
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>