视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
解析PHP标准库SPL数据结构
2020-11-02 18:22:40 责编:小采
文档

SPL提供了双向链表、堆栈、队列、堆、降序堆、升序堆、优先级队列、定长数组、对象容器

SplQueue 队列类

进出异端,先进先出

<?php$obj = new SplQueue();//插入一个节点到top位置$obj->enqueue(1);
$obj->enqueue(2);
$obj->enqueue(3);/**
SplQueue Object
(
 [flags:SplDoublyLinkedList:private] => 4
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 1
 [1] => 2
 [2] => 3
 )

)
*/$obj->offsetSet(0,'C');/**
SplQueue Object
(
 [flags:SplDoublyLinkedList:private] => 4
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 'C'
 [1] => 2
 [2] => 3
 )

)
*/$obj->rewind();//从队列中返回并删除bottom位置的元素$obj->dequeue();/**
'C'

SplQueue Object
(
 [flags:SplDoublyLinkedList:private] => 4
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 2
 [1] => 3
 )

)
*/复制代码

SplStack 堆栈类

单端进出时,后进先出,先进后出

$obj = new SplStack();/**
SplStack Object
(
 [flags:SplDoublyLinkedList:private] => 6
 [dllist:SplDoublyLinkedList:private] => Array
 (
 )

)
*///向堆栈放入一个节点到top位置$obj->push(1);
$obj->push(2);
$obj->push(3);/**
SplStack Object
(
 [flags:SplDoublyLinkedList:private] => 6
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 1
 [1] => 2
 [2] => 3
 )

)
*///堆栈的offset = 0 是Top所在的位置,offset = 1 是top节点靠近bottom位置的相邻节点$obj->offsetSet(0,'C');/**
SplStack Object
(
 [flags:SplDoublyLinkedList:private] => 6
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 1
 [1] => 2
 [2] => 'C'
 )

)
*/$obj->offsetSet(1,'B');/**
SplStack Object
(
 [flags:SplDoublyLinkedList:private] => 6
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 1
 [1] => 'B'
 [2] => 'C'
 )

)
*///堆栈的rewind使指针指向top节点,而双向链表的rewind指向bottom节点$obj->rewind();//堆栈的next是使指针向bottom方向相邻的节点移动一位,而链表是向top方向移动$obj->next();//遍历堆栈$obj->rewind();while($obj->valid()){ echo $obj->key().'=>'.$obj->current();
 $obj->next();
}/**
2=>'C'
1=>'B'
0=>1
*///从堆栈中取出top位置的节点并删除$obj->pop();复制代码

SplDoublyLinkedList 双向链表类

$obj = new SplDoublyLinkedList();//SplDoublyLinkedList Object ( [flags:SplDoublyLinkedList:private] => 0 [dllist:SplDoublyLinkedList:private] => Array ( ) )//把新的节点数据添加到链表的顶部Top$obj->push(1);
$obj->push(2);
$obj->push(3);//把新的节点数据添加到链表底部bottom$obj->unshift(4);/**
SplDoublyLinkedList Object
(
 [flags:SplDoublyLinkedList:private] => 0
 [dllist:SplDoublyLinkedList:private] => Array
 (
 [0] => 4
 [1] => 1
 [2] => 2
 [3] => 3
 )

)
*///在没有调用rewind()方法之前输出为nullecho 'current'.$obj->current();//输出: null//把指针指向bottom节点$obj->rewind();//获取当前指针指向的节点$obj->current();//输出: 4//将执行挪到下一个$obj->next();
$obj->current();//输出: 1$obj->prev();
$obj->current();//输出: 4//越界了$obj->next();
$obj->next();
$obj->next();
$obj->next();
$obj->current();//输出: null//判断当前节点是否有效$obj->valid()//输出: false$obj->prev();
$obj->valid()//输出: true$obj->shift();//把top节点从链表中删除并返回$obj->pop();//输出 3//把bottom节点从链表中删除并返回$obj->shift();//输出 4//返回top节点$obj->top();//返回bottom节点$obj->bottom();复制代码

感谢您的阅读,如果对您有帮助,欢迎关注"CRMEB"。码云上有我们开源的商城项目,知识付费项目,均是基于PHP+vue开发,学习研究欢迎使用,关注我们保持联系!

想了解更多编程学习,敬请关注php培训栏目!

下载本文
显示全文
专题