>백엔드 개발 >PHP 튜토리얼 >PHP SPL 표준 라이브러리의 데이터 구조 스택(SplStack) 소개

PHP SPL 표준 라이브러리의 데이터 구조 스택(SplStack) 소개

PHPz
PHPz원래의
2016-05-16 20:15:591158검색

이 글에서는 주로 PHP SPL 표준 라이브러리의 데이터 구조 스택(SplStack)을 소개합니다. 스택(Stack)은 선형 목록의 한쪽 끝에 요소를 삽입하거나 삭제할 수만 있기 때문에 특별한 선형 목록입니다(즉, 푸시 및 삭제). pop), 도움이 필요한 친구들은

을 참조하세요. Stack은 선형 목록의 한쪽 끝에만 요소를 삽입하거나 삭제할 수 있기 때문에 특별한 선형 목록입니다(예: push 및 pop). Pop)

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

더 많은 관련 튜토리얼을 보려면 초보부터 마스터까지 PHP 프로그래밍에 대한 전체 비디오 튜토리얼 세트

를 방문하세요.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.