zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    log4j 悟寰轩
    初学PHP 悟寰轩
    java基本语法注意问题 悟寰轩
    HTTP协议基础 悟寰轩
    SSHweb.xml详解 悟寰轩
    windows和linux查找被入侵后留下的后门文件 悟寰轩
    MFC Link problem
    Manually Walking a Stack
    linux试用(2)安装 mplayer, g++
    子集和问题
  • 原文地址:https://www.cnblogs.com/Renyi-Fan/p/9099256.html
Copyright © 2011-2022 走看看