PHP 더 블 링크 목록(SplDoubly LinkedList)소개 및 사용 인 스 턴 스

더 블 링크 는 중요 한 선형 저장 구조 로 더 블 링크 의 모든 노드 에 대해 자신의 정 보 를 저장 할 뿐만 아니 라 전구 와 후계 노드 의 주 소 를 저장 해 야 한다.

PHP SPL 의 SplDoubly LinkedList 류 는 더 블 링크 에 대한 동작 을 제공 합 니 다.
SplDoublyLinkedList 클래스 요약 은 다음 과 같 습 니 다.

SplDoublyLinkedList implements Iterator  , ArrayAccess  , Countable  {
 
  public __construct ( void )
  public void add ( mixed $index , mixed $newval )
  //        
  public mixed top ( void )
  //        
  public mixed bottom ( void )
  //        
  public int count ( void )
  //         
  public bool isEmpty ( void )
 
 
  //      
  public mixed key ( void )
  //      
  public void prev ( void )
  //      
  public void next ( void )
  //    
  public mixed current ( void )
  //          
  public void rewind ( void )
  //           
  public bool valid ( void )
 
  //  index       
  public bool offsetExists ( mixed $index )
  //    index    
  public mixed offsetGet ( mixed $index )
  //    index  
  public void offsetSet ( mixed $index , mixed $newval )
  //    index   
  public void offsetUnset ( mixed $index )
 
  //           
  public mixed pop ( void )
  //           
  public void push ( mixed $value )
 
  //     
  public string serialize ( void )
  //    
  public void unserialize ( string $serialized )
 
  //      
  public void setIteratorMode ( int $mode )
  //      SplDoublyLinkedList::IT_MODE_LIFO (Stack style) SplDoublyLinkedList::IT_MODE_FIFO (Queue style)
  public int getIteratorMode ( void )
 
  //          
  public mixed shift ( void )
  //          
  public void unshift ( mixed $value )
 
}
사용 하기 도 쉬 워 요.

$list = new SplDoublyLinkedList();
$list->push('a');
$list->push('b');
$list->push('c');
 
$list->unshift('top');
$list->shift();
 
print_r(array(
  'pop' => $list->pop(),
  'count' => $list->count(),
  'isEmpty' => $list->isEmpty(),
  'bottom' => $list->bottom(),
  'top' => $list->top()
));
 
$list->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO);
print_r($list->getIteratorMode());
 
for($list->rewind(); $list->valid(); $list->next()) {
  echo $list->current().PHP_EOL;
}
 
print_r($a = $list->serialize());
//print_r($list->unserialize($a));
 
$list->offsetSet(0,'new one');
$list->offsetUnset(0);
print_r(array(
  'offsetExists' => $list->offsetExists(4),
  'offsetGet' => $list->offsetGet(0),
 
));
print_r($list);

좋은 웹페이지 즐겨찾기