婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP延遲靜態綁定的深入講解

PHP延遲靜態綁定的深入講解

熱門標簽:遼寧ai電銷機器人價格 上海做外呼線路的通信公司 房產中介用的是什么外呼系統 電話機器人銷售主要負責什么 地圖標注專員怎么樣 福建銀行智能外呼系統價格 寧波外呼營銷系統 四川保險智能外呼系統供應商 長沙做地圖標注公司

前言

所謂延遲靜態綁定,顧名思義,靜態調用時::符號左側的部分的的綁定是延遲,也就是說不再被解析為定義當前方法所在的類,而是在實際運行時計算的。本文主要介紹了關于PHP延遲靜態綁定的相關內容,下面話不多說了,來一起看看詳細的介紹吧。

嗅到了壞的味道

這段時間看項目后臺的PHP代碼,看到了類似于以下的一段代碼,我把它抽出來:

?php
 class DBHandler {
  function get() {}
 }

 class MySQLHandler extends DBHandler {
  // 這里一個create
  public static function create() {
   echo "MySQL";
   return new self();
  }
  public function get() {
   echo "MySQL get()";
  }
 }

 class MemcachedHandler extends DBHandler {
  // 這里又有一個create
  public static function create() {
   echo "Memcached";
   return new self();
  }
  public function get() {
   echo "Memcached get";
  }
 }

 function get(DBHandler $handler) {
  $handler->get();
 }
 $dbHandler = MySQLHandler::create();
 get($dbHandler);
?>

有沒有嗅到壞代碼的味道?可以看到,在MySQLHandler和MemcachedHandler類中,都有一個create函數,除掉我的輸出語句,發現它們一模一樣,這就是代碼冗余。是的,需要進行代碼重構。

進行簡單的重構

代碼重構無處不在,只要你想,你覺的有改進,就需要敲起鍵盤開始干活。來吧,對上面的代碼進行重構,如下:

?php
 class DBHandler {
  public static function create() {
   echo "create";
   return new self();
  }
  function get() {}
 }

 class MySQLHandler extends DBHandler {
  public function get() {
   echo "MySQL get()";
  }
 }

 class MemcachedHandler extends DBHandler {
  public function get() {
   echo "Memcached get";
  }
 }

 function get(DBHandler $handler) {
  $handler->get();
 }
 $dbHandler = MySQLHandler::create();
 get($dbHandler);
?>

將create函數移到DBHandler類中,看起來還不錯,至少少了一坨那糟糕的代碼。

貌似是錯的

運行一下,卻發現,并沒有打印出我們期望的 MySQL get()  。什么情況?這說明,并沒有調用MySQLHandler的get函數,但是代碼明明調用了啊,這說明, new self() 這句代碼有問題。這有什么問題?這就需要說到今天總結的重點了————延遲靜態綁定。

延遲靜態綁定

在PHP5.3以后引入了延遲靜態綁定。再看下面這段代碼:

?php
 class A {
  public static function who() {
   echo __CLASS__;
  }
  public static function test() {
   self::who();
  }
 }

 class B extends A {
  public static function who() {
   echo __CLASS__;
  }
 }
 B::test();
?>

上面的代碼輸出了A,但是我希望它輸出B,這就是問題的所在。這也是 self 和 __CLASS__ 的限制。使用 self:: 或者 __CLASS__ 對當前類的靜態引用,取決于定義當前方法所在的類。所以,這就很好的解釋了為什么上面的代碼輸出了A。但是,如果我們需要輸出B呢?可以這么干:

?php
 class A {
  public static function who() {
   echo __CLASS__;
  }
  public static function test() {
   static::who(); // 這里有變化,后期靜態綁定從這里開始
  }
 }

 class B extends A {
  public static function who() {
   echo __CLASS__;
  }
 }
 B::test();
?>

后期靜態綁定本想通過引入一個新的關鍵字表示運行時最初調用的類來繞過限制。簡單地說,這個關鍵字能夠讓你在上述例子中調用 test() 時引用的類是 B 而不是 A。最終決定不引入新的關鍵字,而是使用已經預留的 static 關鍵字。

這就是后期靜態綁定的根本————static關鍵字的另類用法。對于文章一開始的例子,可以這么改:

return new static(); // 改變這里,后期靜態綁定

這種使用后期靜態綁定,在使用PHP實現23中設計模式的時候,你會感到很輕松的。

總結

就是一個很簡單的知識點,但是卻非常有用,總結起來,還是查了一些資料,補充一下知識點。溫故而知新。好了,希望對大家有幫助。如果大家有什么建議,讓我的文章寫的更好,盡管提出來,我需要大家的幫助。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • PHP靜態延遲綁定和普通靜態效率的對比
  • PHP Static延遲靜態綁定用法分析
  • 簡單談談php延遲靜態綁定
  • php延遲靜態綁定實例分析
  • PHP延遲靜態綁定示例分享
  • PHP 面向對象程序設計(oop)學習筆記 (二) - 靜態變量的屬性和方法及延遲綁定
  • PHP延遲靜態綁定使用方法實例解析

標簽:佛山 深圳 工商登記 常德 宿遷 延安 澳門 宜春

巨人網絡通訊聲明:本文標題《PHP延遲靜態綁定的深入講解》,本文關鍵詞  PHP,延遲,靜態,綁,定的,深入,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP延遲靜態綁定的深入講解》相關的同類信息!
  • 本頁收集關于PHP延遲靜態綁定的深入講解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 三亚市| 乐至县| 陇川县| 海盐县| 阿合奇县| 石城县| 铜梁县| 麻江县| 揭东县| 梁河县| 绥阳县| 太保市| 莲花县| 沙田区| 治县。| 成都市| 博客| 吉木乃县| 营口市| 奉化市| 北海市| 靖安县| 新沂市| 乌拉特中旗| 阿荣旗| 东乌| 正宁县| 宜宾市| 定陶县| 务川| 海口市| 通州区| 永安市| 灵台县| 通化市| 海宁市| 正阳县| 治多县| 雅江县| 宝山区| 清水河县|