微信扫一扫打赏支持

php标准库spl栈SplStack如何使用?

php标准库spl栈SplStack如何使用?

一、总结

php标准库spl栈SplStack介绍。(SplStack类)(各种方法都支持)

1、SplStack:$stack = new SplStack(); //类:new关键字  并且写法为SplStack(两个都大写,后一个大写因为驼峰命名法,前一个大写因为类首字母大写)
2、各种方法都支持:$stack->push('a'); //因为是php类,所以是箭头->调用方法

 

 

二、php标准库spl栈SplStack介绍

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

SplStack就是继承双链表(SplDoublyLinkedList)实现栈。

类摘要如下:

简单使用如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//把栈想象成一个颠倒的数组
$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

 

posted @ 2018-05-28 11:32  范仁义  阅读(525)  评论(0编辑  收藏  举报