SPL学习笔记(2)---类的实现

一:SPL中的双向链表---SplDoublyLinkedList()

  • 双向链表的操作总结
  1. 当前节点的操作:rewind() 指向bottom,current() 当前节点,next() 下一个节点,prev() 上一个节点。
  2. 增加节点的操作:push()会插入到top、unshift()会插入到bottom。
  3. 删除节点的操作:pop() 会删除节点中的top元素、shift() 会删除节点中的bottom元素
  4. 定位操作:bottom()、top()
  5. 特定节点的操作:offsetExsits()、offsetGet()、offsetSet()、offsetUnset()
  • SplDoublyLinkedList的实现

      

 1 <?php
 2 $obj=new SplDoublyLinkedList();
 3 $obj->push(1);
 4 $obj->push(2);
 5 $obj->push(3);
 6 $obj->unshift(10);//在bottom添加
 7 $obj->shift();    //在bottom删除
 8 // $obj->pop();
 9 $obj->rewind();//在调用current等操作前需要调用rewind()
10 $obj->next();  //从bottom到top
11 echo "current:".$obj->current(); //current:2
12 $obj->prev();
13 echo "current:".$obj->current(); //current:1
14 $obj->prev();
15 echo "current:".$obj->current(); //current:(指向空节点)

二:SPL中的堆栈---SplStack()

SPL的堆栈就像一个圆盘,要想把3拿出来,必须把5、7都拿出来。先进后出。

具有先进后出特性的成为堆栈。SplStack继承自SplDoublyLinkedList类、具有父类的一切方法。

注意点:

  1. offset 中,0为top所在的节点。(offset总是最先出来的节点)
  2. current() 在双向链表中指向bottom位置,在堆栈指向top位置。
  3. next()在双向链表由bottom()指向top(),在堆栈中由top()指向bottom()
  4. pop()从top删除。同双向链表。
 1 <?php
 2 $stack = new SplStack();
 3 $stack->push("A");
 4 $stack->push("B");
 5 $stack->offsetSet(0, "C");//B的值设为C
 6 //遍历堆栈
 7 $stack->rewind();
 8 while ($stack->valid()){
 9     echo $stack->key()."=>".$stack->current()."<br>";
10     $stack->next();
11 }//1=>c 0=>A
12 $stack->pop();
13 print_r($stack);//SplStack Object ( [flags:SplDoublyLinkedList:private] => 6 [dllist:SplDoublyLinkedList:private] => Array ( [0] => A ) ) 

三:SPL中的队列---SplQueue()

队列和堆栈正好相反,最先进入队列的元素会先出队列。

类比于排队打饭,排到最前面的人总是最先能够打到饭。

继承自SplDoublyLinkedList()

进入队列:enqueue()进入队列   dequeue()退出队列

注意点:

  1. offset 中,0为bottom所在的节点。(offset总是最先出来的节点)
  2. current() 在双向链表中指向bottom位置,在队列指向bottom位置。
  3. next()在双向链表由bottom()指向top(),在队列由bottom()指向top()。
  4. dequeue()删除bottom()节点。
1 <?php
2 $queue=new SplQueue();
3 $queue->enqueue(1);
4 $queue->enqueue(2);
5 $queue->enqueue(3);
6 $queue->dequeue();//1会退出队列
7 $queue->offsetSet(0, "b");
8 $queue->rewind();
9 echo "current:".$queue->current();//b
时间: 2024-10-11 20:06:43

SPL学习笔记(2)---类的实现的相关文章

C++ Primer 学习笔记_19_类与数据抽象(5)_初始化列表(const和引用成员)、拷贝构造函数

C++ Primer 学习笔记_19_类与数据抽象(5)_初始化列表(const和引用成员).拷贝构造函数  从概念上将,可以认为构造函数分为两个阶段执行: 1)初始化阶段: 2)普通的计算阶段.计算阶段由构造函数函数体中的所有语句组成. 一.构造函数初始化列表 推荐在构造函数初始化列表中进行初始化 1.对象成员及其初始化 <span style="font-size:14px;">#include <iostream> using namespace std;

Java学习笔记_25_Collections类

25.Collections类: Collections类是一个工具类,用来对集合进行操作,它主要是提供一些排序算法,包括随机排序.反相排序等. Collections类提供了一些静态方法,实现了基于List容器的一些常用算法. Collections的一些方法列表: · void sort(List): 对List内的元素进行排序. · void shuffle(List): 对List内的元素随机排序. · void reverse(List): 对List内的元素进行逆序排列. · voi

C++ Primer 学习笔记_56_类与数据抽象 --消息处理示例

复制控制 --消息处理示例 说明: 有些类为了做一些工作需要对复制进行控制.为了给出这样的例子,我们将概略定义两个类,这两个类可用于邮件处理应用程序.Message类和 Folder类分别表示电子邮件(或其他)消息和消息所出现的目录,一个给定消息可以出现在多个目录中.Message上有 save和 remove操作,用于在指定Folder中保存或删除该消息. 数据结构: 对每个Message,我们并不是在每个Folder中都存放一个副本,而是使每个Message保存一个指针集(set),set中

C++ Primer 学习笔记_57_类与数据抽象 --管理指针成员

复制控制 --管理指针成员 引言: 包含指针的类需要特别注意复制控制,原因是复制指针时只是复制了指针中的地址,而不会复制指针指向的对象! 将一个指针复制到另一个指针时,两个指针指向同一对象.当两个指针指向同一对象时,可能使用任一指针改变基础对象.类似地,很可能一个指针删除了一对象时,另一指针的用户还认为基础对象仍然存在.指针成员默认具有与指针对象同样的行为. 大多数C++类采用以下三种方法之一管理指针成员: 1)指针成员采取常规指针型行为:这样的类具有指针的所有缺陷但无需特殊的复制控制! 2)类

C++ Primer 学习笔记_55_类与数据抽象 --析构函数

复制控制 --析构函数 引言: 在构造函数中分配了资源之后,需要一个对应操作自动回收或释放资源.析构函数就是这样的一个特殊函数,它可以完成所需的资源回收,作为类构造函数的补充. 1.何时调用析构函数 撤销类对象时会自动调用析构函数: Sales_item *p = new Sales_item; { Sales_item item(*p); //调用复制构造函数 delete p; //调用指针p的析构函数 } //调用对象item的析构函数 动态分配的对象只有在指向该对象的指针被删除时才撤销,

C++ Primer 学习笔记_53_类与数据抽象 --友元、static成员

类 --友元.static成员 一.友元 友元机制允许一个类将对其非公有成员的访问权授予指定的函数或类(对未被授权的函数或类,则阻止其访问):友元的声明以关键字friend开始,但是它只能出现在类定义的内部.友元声明可以出现在类中的任何地方:友元不是授予友元关系的那个类的成员,所以它们不受其声明出现部分的访问控制影响. [最佳实践] 通常,将友元声明成组的放在类定义的开始或结尾是个好主意! 1.友元关系:一个例子 假设一个窗口管理类Window_Mgr可能需要访问由其管理的Screen对象的内部

C++ Primer 学习笔记_54_类与数据抽象 --复制构造函数、赋值操作符

复制控制 --复制构造函数.赋值操作符 引言: 当定义一个新类型时,需要显式或隐式地指定复制.赋值和撤销该类型的对象时会发生什么– 复制构造函数.赋值操作符和析构函数的作用!      复制构造函数:具有单个形参,该形参(常用const修饰)是对该类类型的引用.当定义一个新对象并用一个同类型的对象对它进行初始化时,将显式的使用复制构造函数:当将该类型的对象传递给函数或者从函数返回该类型的对象时,将隐式使用复制构造函数.     析构函数:作为构造函数的互补,当对象超出作用域或动态分配的对象被删除

Swift学习笔记:类和结构

一.类和结构的异同 类和结构有一些相似的地方,它们都可以: 1. 定义一些可以赋值的属性: 2. 定义具有功能性的方法 3. 定义下标,使用下标语法 4. 定义初始化方法来设置初始状态 5. 在原实现方法上的可扩展性 根据协议提供某一特定类别的基本功能 1. 类还有一些结构不具备的特性: 2. 类的继承性 3. 对类实例实时的类型转换 4. 析构一个类的实例使之释放空间 5. 引用计数,一个类实例可以有多个引用 1. 定义语法 struct Name{ let firstName = "&quo

C++ Primer 学习笔记_24_类与数据抽象(10)--static 与单例模式、auto_ptr与单例模式、const成员函数、const 对象、mutable修饰符

C++ Primer 学习笔记_24_类与数据抽象(10)--static 与单例模式.auto_ptr与单例模式.const成员函数.const 对象.mutable修饰符 前言 [例]写出面向对象的五个基本原则? 解答:单一职责原则,开放封闭原则,依赖倒置原则,接口隔离原则和里氏替换原则 里氏替换原则:子类型必须能够替换他们的基类型. 设计模式分为三种类型:创建型模式.结构型模式和行为型模式 一.static 与单例模式 1.单例模式 单例模式的意图:保证一个类仅有一个实例,并提供一个访问它

C++ Primer 学习笔记_16_类与数据抽象(2)_隐含的this指针

C++ Primer 学习笔记_16_类与数据抽象(2)_隐含的this指针 1.引言 在前面提到过,成员函数具有一个附加的隐含形参,即指向该类对象的一个指针.这个隐含形参命名为this. 2.返回*this 成员函数有一个隐含的附加形参,即指向该对象的指针,这个隐含的形参叫做this指针(编译器自动传递)使用this指针保证了每个对象可以拥有不同数值的数据成员,但处理这些成员的代码可以被所有对象共享.成员函数是只读的代码,由所有对象共享,并不占对象的存储空间,因为this指针指向当前对象,所以