PHP Predefined Interfaces 預定義接口

6個迭代器接口介紹
服務器君一共花費了114.208 ms進行了5次數據庫查詢,努力地為您提供了這個頁面。
試試閱讀模式?希望聽取您的建議

SPL提供了6個迭代器接口:

Traversable遍歷接口(檢測一個類是否可以使用?foreach?進行遍歷的接口)
Iterator迭代器接口(可在內部迭代自己的外部迭代器或類的接口)
IteratorAggregate聚合式迭代器接口(創建外部迭代器的接口)
OuterIterator迭代器嵌套接口(將一個或多個迭代器包裹在另一個迭代器中)
RecursiveIterator遞歸迭代訪問接口(提供遞歸訪問功能)
SeekableIterator可索引迭代訪問接口(實現查找功能)

下面對各種迭代器接口簡單介紹一下:

1. Traversable

Traversable接口實際上不是一個接口,在實際寫php代碼中不能用。因為只有內部的PHP類(用C寫的類)才可以直接實現Traversable接口。可以說這是個特性級別的東西。實際的PHP編程中我們使用Iterator接口或者IteratorAggregate接口來實現遍歷。

Traversable {
}

Traversable 接口不能直接實現(implements).Traversable 重要的一個用處就是判斷一個類是否可以遍歷:

if($class instanceof Traversable)
{
     //foreach...
}

下面是官方例子:

<?php
    if( !is_array( $items ) && !$items instanceof Traversable )
        //Throw exception here
?>

2. Iterator

Iterator接口的主要用途是允許一個類實現一個基本的迭代功能,從而使它可以被循環訪問,根據鍵值訪問以及回滾。Iterator接口摘要如下:

Iterator extends Traversable  
{  
    //返回當前索引游標指向的元素  
    abstract public mixed current(void)  
    //返回當前索引游標指向的元素的鍵名  
    abstract public scalar key(void)  
    //移動當前索引游標指向下一元素  
    abstract public void next(void)  
    //重置索引游標的指向第一個元素  
    abstract public void rewind(void)  
    //判斷當前索引游標指向的是否是一個元素,常常在調用 rewind()或 next()使用  
    abstract public boolean valid(void)  
} 

外部迭代器接口,實現該接口的對象可以迭代自己內部的數據。

Iterator 的例子這里就不再列舉了,本專題前面部分以后后續有很多例子,具體請自行查看。

3. IteratorAggregate

又叫聚合式迭代器。創建外部迭代器的接口,其摘要如下:

IteratorAggregate extends Traversable {  
	//實現該方法時,必須返回一個實現了Iterator接口的類的實例  
	abstract public Traversable getIterator ( void )  
} 

其中getIterator 方法返回值必須是能遍歷或實現Iterator接口(must be traversable or implement interface Iterator)。SPL還提供了一些專門用來與IteratorAggregate接口一起使用的內置迭代器。使用這些迭代器意味著只需要實現一個方法并實例化一個類就可以使對象可以迭代訪問了。

實例:

/**
* @author 簡明現代魔法 http://www.snpmgr.live
*/
class myData implements IteratorAggregate  
{  
    public $property1 = "公共屬性1";  
    public $property2 = "公共屬性2";  
    public $property3 = "公共屬性3";  
  
    public function __construct()  
    {  
        $this->property4 = "最后一個公共屬性";  
    }  
  
    public function getIterator()  
    {  
        return new ArrayIterator($this);  
    }  
}  
  
$obj = new myData;  
foreach ($obj as $key => $value) {  
    echo "鍵名:{$key}  值:{$value}\n";  
} 

程序輸出:

鍵名:property1  值:公共屬性1
鍵名:property2  值:公共屬性2
鍵名:property3  值:公共屬性3
鍵名:property4  值:最后一個公共屬性

4. ArrayAccess

數組式訪問接口。實現該接口的對象能像數組一樣使用:

ArrayAccess {
	/* Methods */
	abstract public boolean offsetExists ( mixed $offset )
	abstract public mixed offsetGet ( mixed $offset )
	abstract public void offsetSet ( mixed $offset , mixed $value )
	abstract public void offsetUnset ( mixed $offset )
}
  • ArrayAccess::offsetExists?— 檢查一個偏移位置是否存在
  • ArrayAccess::offsetGet?— 獲取一個偏移位置的值
  • ArrayAccess::offsetSet?— 設置一個偏移位置的值
  • ArrayAccess::offsetUnset?— 復位一個偏移位置的值

舉個栗子:

/**
* @author 簡明現代魔法 http://www.snpmgr.live
*/
class obj implements arrayaccess {
    private $container = array();
    public function __construct() {
        $this->container = array(
            "one"   => 1,
            "two"   => 2,
            "three" => 3,
        );
    }
    public function offsetSet($offset, $value) {
        if (is_null($offset)) {
            $this->container[] = $value;
        } else {
            $this->container[$offset] = $value;
        }
    }
    public function offsetExists($offset) {
        return isset($this->container[$offset]);
    }
    public function offsetUnset($offset) {
        unset($this->container[$offset]);
    }
    public function offsetGet($offset) {
        return isset($this->container[$offset]) ? $this->container[$offset] : null;
    }
}

$obj = new obj;

var_dump(isset($obj["two"]));
var_dump($obj["two"]);
unset($obj["two"]);
var_dump(isset($obj["two"]));
$obj["two"] = "A value";
var_dump($obj["two"]);
$obj[] = 'Append 1';
$obj[] = 'Append 2';
$obj[] = 'Append 3';
print_r($obj);

5. Serializable

序列化接口。實現該接口的類不能使用__sleep() 和__wakeup().在serialize時不執行__destruct(),在unserialize不執行__construct()。

Serializable {
	/* Methods */
	abstract public string serialize ( void )
	abstract public mixed unserialize ( string $serialized )
}

實現此接口的類將不再支持 __sleep() 和 __wakeup()。不論何時,只要有實例需要被序列化,serialize 方法都將被調用。它將不會調用 __destruct() 或有其他影響,除非程序化地調用此方法。當數據被反序列化時,類將被感知并且調用合適的 unserialize() 方法而不是調用 __construct()。如果需要執行標準的構造器,你應該在這個方法中進行處理。

  • Serializable::serialize?— 對象的字符串表示
  • Serializable::unserialize?— 構造對象
Serializable {
	/* Methods */
	abstract public string serialize ( void )
	abstract public mixed unserialize ( string $serialized )
}

例子:

class obj implements Serializable {
    private $data;
    public function __construct() {
        $this->data = "My private data";
    }
    public function serialize() {
        return serialize($this->data);
    }
    public function unserialize($data) {
        $this->data = unserialize($data);
    }
    public function getData() {
        return $this->data;
    }
}

$obj = new obj;
$ser = serialize($obj);

$newobj = unserialize($ser);

var_dump($newobj->getData());

6. Closure

Closure {
	/* 方法 */
	__construct ( void )
	public static Closure bind ( Closure $closure , object $newthis [, mixed $newscope = 'static' ] )
	public Closure bindTo ( object $newthis [, mixed $newscope = 'static' ] )
}

這個具體還沒研究,具體可以去看官方文檔:http://www.php.net/manual/en/reserved.interfaces.php

延伸閱讀

此文章所在專題列表如下:

  1. 看看PHP迭代器的內部執行過程
  2. 用PHP迭代器來實現一個斐波納契數列
  3. PHP SPL,被遺落的寶石
  4. PHP數據結構預熱:PHP的迭代器
  5. PHP Predefined Interfaces 預定義接口

本文地址:http://www.snpmgr.live/librarys/veda/detail/2167,歡迎訪問原出處。

不打個分嗎?

轉載隨意,但請帶上本文地址:

http://www.snpmgr.live/librarys/veda/detail/2167

如果你認為這篇文章值得更多人閱讀,歡迎使用下面的分享功能。
小提示:您可以按快捷鍵 Ctrl + D,或點此 加入收藏

大家都在看

閱讀一百本計算機著作吧,少年

很多人覺得自己技術進步很慢,學習效率低,我覺得一個重要原因是看的書少了。多少是多呢?起碼得看3、4、5、6米吧。給個具體的數量,那就100本書吧。很多人知識結構不好而且不系統,因為在特定領域有一個足夠量的知識量+足夠良好的知識結構,系統化以后就足以應對大量未曾遇到過的問題。

奉勸自學者:構建特定領域的知識結構體系的路徑中再也沒有比學習該專業的專業課程更好的了。如果我的知識結構體系足以囊括面試官的大部分甚至吞并他的知識結構體系的話,讀到他言語中的一個詞我們就已經知道他要表達什么,我們可以讓他坐“上位”畢竟他是面試官,但是在知識結構體系以及心理上我們就居高臨下。

所以,閱讀一百本計算機著作吧,少年!

《數據結構與算法分析:C++描述(第3版)》 維斯 (Mark Allen Weiss) (作者), 張懷勇 (譯者), 等 (譯者)

《數據結構與算法分析:C++描述(第3版)》是數據結構和算法分析的經典教材,書中使用主流的程序設計語言C++作為具體的實現語言。書的內容包括表、棧、隊列、樹、散列表、優先隊列、排序、不相交集算法、圖論算法、算法分析、算法設計、攤還分析、查找樹算法、k-d樹和配對堆等。《數據結構與算法分析:C++描述(第3版)》適合作為計算機相關專業本科生的數據結構課程和研究生算法分析課程的教材。本科生的數據結構課程可以使用《數據結構與算法分析:C++描述(第3版)》第1章~第9章,多學時課程還可以講解第10章;研究生算法分析課程可以使用第6章~第12章。

更多計算機寶庫...

燃烧吧足球登陆