当前位置: 移动技术网 > IT编程>开发语言>PHP > PHP SPL标准库之数据结构栈(SplStack)介绍

PHP SPL标准库之数据结构栈(SplStack)介绍

2019年05月30日  | 移动技术网IT编程  | 我要评论

栈(stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈)

splstack就是继承双链表(spldoublylinkedlist)实现栈。

类摘要如下:

简单使用如下:

//把栈想象成一个颠倒的数组
$stack = new splstack();
/**
 * 可见栈和双链表的区别就是iteratormode改变了而已,栈的iteratormode只能为:
 * (1)spldoublylinkedlist::it_mode_lifo | spldoublylinkedlist::it_mode_keep (默认值,迭代后数据保存)
 * (2)spldoublylinkedlist::it_mode_lifo | spldoublylinkedlist::it_mode_delete (迭代后数据删除)
 */
$stack->setiteratormode(spldoublylinkedlist::it_mode_lifo | spldoublylinkedlist::it_mode_delete);
$stack->push('a');
$stack->push('b');
$stack->push('c');
 
$stack->pop(); //出栈
 
$stack->offsetset(0, 'first');//index 为0的是最后一个元素
 
foreach($stack as $item) {
 echo $item . php_eol; // first a
}
 
print_r($stack); //测试iteratormode


如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网