PHP 双链表(SplDoublyLinkedList)简介和使用实例

 更新时间:2015年05月12日 09:37:52   投稿:junjie  
这篇文章主要介绍了PHP 双链表(SplDoublyLinkedList)简介和使用实例的相关资料,需要的朋友可以参考下

双链表是一种重要的线性存储结构,对于双链表中的每个节点,不仅仅存储自己的信息,还要保存前驱和后继节点的地址。

PHP SPL中的SplDoublyLinkedList类提供了对双链表的操作。
SplDoublyLinkedList类摘要如下:

SplDoublyLinkedList implements Iterator  , ArrayAccess  , Countable  {
 
  public __construct ( void )
  public void add ( mixed $index , mixed $newval )
  //双链表的头部节点
  public mixed top ( void )
  //双链表的尾部节点
  public mixed bottom ( void )
  //双联表元素的个数
  public int count ( void )
  //检测双链表是否为空
  public bool isEmpty ( void )
 
 
  //当前节点索引
  public mixed key ( void )
  //移到上条记录
  public void prev ( void )
  //移到下条记录
  public void next ( void )
  //当前记录
  public mixed current ( void )
  //将指针指向迭代开始处
  public void rewind ( void )
  //检查双链表是否还有节点
  public bool valid ( void )
 
  //指定index处节点是否存在
  public bool offsetExists ( mixed $index )
  //获取指定index处节点值
  public mixed offsetGet ( mixed $index )
  //设置指定index处值
  public void offsetSet ( mixed $index , mixed $newval )
  //删除指定index处节点
  public void offsetUnset ( mixed $index )
 
  //从双链表的尾部弹出元素
  public mixed pop ( void )
  //添加元素到双链表的尾部
  public void push ( mixed $value )
 
  //序列化存储
  public string serialize ( void )
  //反序列化
  public void unserialize ( string $serialized )
 
  //设置迭代模式
  public void setIteratorMode ( int $mode )
  //获取迭代模式SplDoublyLinkedList::IT_MODE_LIFO (Stack style) SplDoublyLinkedList::IT_MODE_FIFO (Queue style)
  public int getIteratorMode ( void )
 
  //双链表的头部移除元素
  public mixed shift ( void )
  //双链表的头部添加元素
  public void unshift ( mixed $value )
 
}

使用起来也是简单

$list = new SplDoublyLinkedList();
$list->push('a');
$list->push('b');
$list->push('c');
 
$list->unshift('top');
$list->shift();
 
print_r(array(
  'pop' => $list->pop(),
  'count' => $list->count(),
  'isEmpty' => $list->isEmpty(),
  'bottom' => $list->bottom(),
  'top' => $list->top()
));
 
$list->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO);
print_r($list->getIteratorMode());
 
for($list->rewind(); $list->valid(); $list->next()) {
  echo $list->current().PHP_EOL;
}
 
print_r($a = $list->serialize());
//print_r($list->unserialize($a));
 
$list->offsetSet(0,'new one');
$list->offsetUnset(0);
print_r(array(
  'offsetExists' => $list->offsetExists(4),
  'offsetGet' => $list->offsetGet(0),
 
));
print_r($list);

相关文章

  • thinkPHP5.0框架独立配置与动态配置方法

    thinkPHP5.0框架独立配置与动态配置方法

    这篇文章主要介绍了thinkPHP5.0框架独立配置与动态配置方法,结合实例形式分析了thinkPHP5.0框架独立配置与静态配置的功能、实现技巧与相关注意事项,需要的朋友可以参考下
    2017-03-03
  • php 伪静态之IIS篇

    php 伪静态之IIS篇

    上篇文章我们讲解了APACHE服务器下伪静态的实现,不过在国内还是IIS的服务器要多些,特别是个人站长,那么,我们再来学习下IIS下php伪静态的实现过程吧
    2014-06-06
  • php设计模式之单例模式用法经典示例分析

    php设计模式之单例模式用法经典示例分析

    这篇文章主要介绍了php设计模式之单例模式用法,结合具体实例形式分析了php单例模式的概念、原理、定义及使用方法,需要的朋友可以参考下
    2019-09-09
  • PHP操作Redis常用命令的实例详解

    PHP操作Redis常用命令的实例详解

    这篇文章主要介绍了PHP操作Redis常用命令的实例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • yii2 数据库读写分离配置示例

    yii2 数据库读写分离配置示例

    本篇文章主要介绍了yii2 数据库读写分离配置示例,数据库读写分离是在网站遇到性能瓶颈的时候最先考虑优化的步骤,有兴趣的可以了解一下。
    2017-02-02
  • Thinkphp 框架扩展之数据库驱动常用方法小结

    Thinkphp 框架扩展之数据库驱动常用方法小结

    这篇文章主要介绍了Thinkphp 框架扩展之数据库驱动常用方法,总结分析了Thinkphp数据库驱动常用方法、功能及相关使用注意事项,需要的朋友可以参考下
    2020-04-04
  • Laravel框架下载,安装及路由操作图文详解

    Laravel框架下载,安装及路由操作图文详解

    这篇文章主要介绍了Laravel框架下载,安装及路由操作,结合实例形式详细分析了laravel框架的下载、安装、配置、路由等相关操作原理与使用技巧,需要的朋友可以参考下
    2019-12-12
  • php xml留言板 xml存储数据的简单例子

    php xml留言板 xml存储数据的简单例子

    php xml留言板 xml存储数据的简单例子 php操作xml的简单留言板,带分页,仅供参考
    2009-08-08
  • PHP中使用file_get_contents post数据代码例子

    PHP中使用file_get_contents post数据代码例子

    这篇文章主要介绍了PHP中使用file_get_contents post数据代码例子,本文直接给出代码实例,需要的朋友可以参考下
    2015-02-02
  • PHP session文件独占锁引起阻塞问题解决方法

    PHP session文件独占锁引起阻塞问题解决方法

    这篇文章主要介绍了PHP session文件独占锁引起阻塞,本文讲解PHP使用默认文件会话处理器时容易导致的阻塞问题解决方法,需要的朋友可以参考下
    2015-05-05

最新评论