PHP SPL标准库之数据结构栈(SplStack)介绍
程序员文章站
2023-12-10 13:47:34
栈(stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈)
splstack就是继承双链表(spldoublylinkedlist...
栈(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
推荐阅读