陣列接口的樂趣
關鍵要點
- PHP 的數組接口允許程序員在自定義類中模擬原生數據類型的特性,類似於 Python 的方法。這使得自定義類能夠像數組一樣工作,並允許使用常見的數組操作,例如計數元素、循環遍曆元素以及通過索引訪問元素。
- 接口就像類的契約,指定類必須包含的方法。它們允許封裝實現細節並提供語法糖,從而提高代碼的可讀性和可維護性。 PHP 提供了一個預定義接口庫,可以實現這些接口以使對像類似於數組。
- PHP 中的
Countable
、ArrayAccess
和Iterator
接口分別允許對像傳遞count()
方法、像映射一樣被訪問以及迭代集合。這些接口可用於創建更動態和交互式的對象,例如可以計算其推文數量、循環遍歷它們以及通過其 ID 訪問推文的 Twitter 時間線類。
作為一名每天使用不同編程語言的程序員,我非常享受學習其他語言中不同的事物,並嘗試在 PHP 中實現相同的功能。我特別喜歡 Python 中如何在自定義類中模擬原生數據類型的特性。
例如,這個成員列表類:
class Members { public function __construct(array $members) { $this->members = $members; } // 其他方法 }
通過實現 __iter__
方法,您可以像迭代列表(PHP 中的數組)一樣迭代此類實例中的數據:
class Members implements Iterator { private $members; private $position = 0; public function __construct(array $members) { $this->members = $members; } public function current() { return $this->members[$this->position]; } public function key() { return $this->position; } public function next() { $this->position++; } public function rewind() { $this->position = 0; } public function valid() { return isset($this->members[$this->position]); } } $ls = new Members(["你", "我"]); foreach ($ls as $member) { echo $member . "\n"; }
成員資格測試只需實現 __contains__
方法:
class Members { public function __construct(array $members) { $this->members = $members; } public function contains($member) { return in_array($member, $this->members); } } $members = new Members(["你", "我"]); if ($members->contains("我")) { echo "我是一个成员!\n"; }
我認為如果可以在自定義類的實例(不僅僅是數組)中在 PHP 中執行以下操作,那就太好了:
isset($myObject["test"]);
PHP 允許我們使用數組接口來實現這一點。
簡述接口
將接口視為指定類必須包含的方法的契約。
interface Multiplier { public function multiply($num1, $num2); }
使用此接口的任何類都必須具有此 multiply
方法。有一個關鍵字表示類滿足此契約:implements
。
class SmartMultiplier implements Multiplier { public function multiply($num1, $num2) { return $num1 * $num2; } }
只要滿足契約,實現方式就無關緊要。實現 multiply
方法的另一種方法如下:
class NotSoSmartMultiplier implements Multiplier { public function multiply($num1, $num2) { $product = $num1; for ($i = 1; $i < $num2; $i++) { $product += $num1; } return $product; } }
SPL 和 PHP 接口
PHP 提供了一個預定義接口庫,只需在類中實現這些接口,就可以使我們的對像類似於數組。
其中一些接口包含在預定義接口和類列表中,一些包含在標準 PHP 庫 (SPL) 中。
如果這些術語聽起來令人生畏,請不要擔心。您之前都使用過 $_GET
。 $_GET
是一個被稱為預定義的語言結構。
另一方面,根據文檔,SPL 只是
一個旨在解決常見問題的接口和類集合。
現在要做的是看看這些接口的實際應用。讓我們深入研究一下!
我們將創建一個 Twitter 時間線類,
class Members { public function __construct(array $members) { $this->members = $members; } // 其他方法 }
能夠計算其推文數量,
class Members implements Iterator { private $members; private $position = 0; public function __construct(array $members) { $this->members = $members; } public function current() { return $this->members[$this->position]; } public function key() { return $this->position; } public function next() { $this->position++; } public function rewind() { $this->position = 0; } public function valid() { return isset($this->members[$this->position]); } } $ls = new Members(["你", "我"]); foreach ($ls as $member) { echo $member . "\n"; }
循環遍歷它們,
class Members { public function __construct(array $members) { $this->members = $members; } public function contains($member) { return in_array($member, $this->members); } } $members = new Members(["你", "我"]); if ($members->contains("我")) { echo "我是一个成员!\n"; }
並通過推文 ID 獲取推文,
isset($myObject["test"]);
就像我們在普通數組中一樣!
不過,我們必須先解決一些問題。如果您還沒有 Twitter 帳戶,請先創建一個。現在註冊一個開發者帳戶並生成訪問令牌和密鑰。
接下來,從 Github 下載或克隆代碼,並在源文件夾內運行 composer install
。如果您不熟悉 Composer,請參閱 SitePoint 之前的文章。打開 index.php
文件並添加必要的 OAuth 數據。
Countable
接口
Countable
接口可能是最不言自明的。只需實現 count
方法,就可以將對像傳遞給 count()
方法。
我們可以通過對“/users/show”執行 GET 請求來獲取用戶的推文數量。
interface Multiplier { public function multiply($num1, $num2); }
ArrayAccess
接口
我們現在將通過學習一個更有趣的接口來提高難度。
實現後,ArrayAccess
將使我們的對象能夠像映射一樣被訪問,這正是它們的本質。要實現的方法是
class SmartMultiplier implements Multiplier { public function multiply($num1, $num2) { return $num1 * $num2; } }
這在我們的 Twitter 時間線對像中非常方便。測試推文是否存在於時間線中可以通過將我們的對像傳遞給 isset
來完成,如下所示:
class NotSoSmartMultiplier implements Multiplier { public function multiply($num1, $num2) { $product = $num1; for ($i = 1; $i < $num2; $i++) { $product += $num1; } return $product; } }
為此,我們只需對推文 ID 執行 GET 請求。
$tweets = new Timeline("jeunito");
更好的是,我們還可以將上述內容用於 offsetGet
,並讓 offsetExists
依次調用 offsetGet
。
使用 offsetUnset
,我們還可以通過推文 ID 進行刪除,但我將把這留給您去實現。
不幸的是,實現 offsetSet
沒有多大意義。對於這樣的事情,簡單的解決方法是拋出自定義異常,例如 UnsupportedOperationException
。但另一方面,這也可能取決於您的應用程序的特定業務規則。
Iterator
接口
我把最喜歡的接口留到最後! Iterator
接口在這裡非常有用,因為我認為沒有比像迭代普通數組一樣迭代時間線對象更好的方法來封裝遠程集合分頁的細節了。
首先,需要實現以下方法:
count($tweets);
我們可以顯式地使用上述方法來循環遍歷我們的時間線,如下所示:
foreach ($tweets as $tweet) { echo $tweet; }
但是,為什麼這樣做,當您可以這樣做時:
// 获取 if (isset($tweets["some tweet id"])) { echo $tweets["some tweet id"]; }
在我們的示例中,我們將通過按時間順序檢索推文塊並將它們存儲在緩衝區中來循環遍歷時間線中的推文。我們將迭代此緩衝區,直到它用盡,然後我們使用最後一個推文的 ID 作為偏移量來獲取另一批推文。
最初我們沒有任何推文,這就是 rewind
方法的用武之地:獲取最新的 10 條推文,以便從我們可以獲取接下來的 10 條推文的地方開始偏移。
class Members { public function __construct(array $members) { $this->members = $members; } // 其他方法 }
valid()
方法只是用於指示是否繼續循環。這可以通過檢查我們的推文緩衝區是否為空來完成:
class Members implements Iterator { private $members; private $position = 0; public function __construct(array $members) { $this->members = $members; } public function current() { return $this->members[$this->position]; } public function key() { return $this->position; } public function next() { $this->position++; } public function rewind() { $this->position = 0; } public function valid() { return isset($this->members[$this->position]); } } $ls = new Members(["你", "我"]); foreach ($ls as $member) { echo $member . "\n"; }
key()
和 current()
方法只是返回我們迭代中當前推文的鍵和值。出於我們的目的,我們將簡單地從緩衝區中獲取推文 ID 和最新推文的文本。
class Members { public function __construct(array $members) { $this->members = $members; } public function contains($member) { return in_array($member, $this->members); } } $members = new Members(["你", "我"]); if ($members->contains("我")) { echo "我是一个成员!\n"; }
最後是 next
方法。在這裡,我們從緩衝區的頭部出隊以獲取要迭代的下一個元素。然後,如果我們位於緩衝區的最後一個元素,我們將確保獲取下一組推文。
isset($myObject["test"]);
我們完成了!這是一個非常基本的循環遍歷用戶推文的實現。還可以做更多的事情,例如本地緩存以節省API 調用,但這就是使用接口的美妙之處:它們允許我們在後台更改我們的策略,只要我們的實現仍然正確,我們就可以期望它仍然有效。
但是現在,您可以通過在命令行中運行 php index.php
來觀察我們的時間線對象的工作情況。
結論
接口的好處是雙重的。它們允許我們封裝實現細節並為我們提供語法糖,這兩者在任何需要互操作性的應用程序中都非常有用。如果您有任何問題或意見,請在下面的評論部分留下它們!
以上是陣列接口的樂趣的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

PHP8.1中的枚舉功能通過定義命名常量增強了代碼的清晰度和類型安全性。 1)枚舉可以是整數、字符串或對象,提高了代碼可讀性和類型安全性。 2)枚舉基於類,支持面向對象特性,如遍歷和反射。 3)枚舉可用於比較和賦值,確保類型安全。 4)枚舉支持添加方法,實現複雜邏輯。 5)嚴格類型檢查和錯誤處理可避免常見錯誤。 6)枚舉減少魔法值,提升可維護性,但需注意性能優化。

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

RESTAPI設計原則包括資源定義、URI設計、HTTP方法使用、狀態碼使用、版本控制和HATEOAS。 1.資源應使用名詞表示並保持層次結構。 2.HTTP方法應符合其語義,如GET用於獲取資源。 3.狀態碼應正確使用,如404表示資源不存在。 4.版本控制可通過URI或頭部實現。 5.HATEOAS通過響應中的鏈接引導客戶端操作。

在PHP中,異常處理通過try,catch,finally,和throw關鍵字實現。 1)try塊包圍可能拋出異常的代碼;2)catch塊處理異常;3)finally塊確保代碼始終執行;4)throw用於手動拋出異常。這些機制幫助提升代碼的健壯性和可維護性。

匿名類在PHP中的主要作用是創建一次性使用的對象。 1.匿名類允許在代碼中直接定義沒有名字的類,適用於臨時需求。 2.它們可以繼承類或實現接口,增加靈活性。 3.使用時需注意性能和代碼可讀性,避免重複定義相同的匿名類。
