欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP對象相關知識總結

 更新時間:2017年04月09日 10:13:41   投稿:hebedich  
這篇文章主要介紹了PHP對象相關知識總結的相關資料,需要的朋友可以參考下

對象傳遞:一種說法是“PHP對象是通過引用傳遞的”,更準確的說法是別名(標識符)傳遞,即它們都保存著同一個標識符(ID)的拷貝,這個標識符指向同一個對象的真正內容。

 <?php
 class A {
   public $foo = 1;
 } 
 
 $a = new A;
 $b = $a;   // $a ,$b都是同一個標識符的拷貝
       // ($a) = ($b) = <id>
 $b->foo = 2;
 echo $a->foo."\n";//2

 $c = new A;
 $d = &$c;  // $c ,$d是引用
       // ($c,$d) = <id>
 
 $d->foo = 2;
 echo $c->foo."\n";//2
 
 $e = new A;
 
 function foo($obj) {
   // ($obj) = ($e) = <id>
   $obj->foo = 2;
 }
 
 foo($e);
 echo $e->foo."\n";//2

•對象復制:對象復制可以通過 clone 關鍵字來完成,如果原對象定義了 __clone() 方法,則新對象中的 __clone() 方法將在復制完后被調用,__clone() 方法可用于修改復制對象屬性的值。當對象被復制后,會對對象的所有屬性執(zhí)行一個淺復制(shallow copy),但所有的引用屬性仍然會是一個指向原來的變量的引用。

 <?php
 class SubObject
 {
   static $instances = 0;
   public $instance;
 
   public function __construct()
   {
     $this->instance = ++self::$instances;
   }
 
   public function __clone()
   {
     $this->instance = ++self::$instances;
   }
 }
 
 class MyCloneable
 {
   public $object1;
   public $object2;
 
   function __clone()
   {
     // 強制復制一份this->object, 否則仍然指向同一個對象
     $this->object1 = clone $this->object1;
   }
   
   function cloneTest()
   {
     echo 'cloneTest';
   }
 }
 
 $obj = new MyCloneable();
 
 $obj->object1 = new SubObject();
 $obj->object2 = new SubObject();
 
 $obj2 = clone $obj;
 
 print("Original Object:\n");
 print_r($obj);
 
 print("Cloned Object:\n");
 print_r($obj2);
 echo $obj2->cloneTest().":\n";
 echo (new Reflectionclass($obj2));

上例輸出結果:

Original Object:
MyCloneable Object
(
  [object1] => SubObject Object
    (
      [instance] => 1
    )

  [object2] => SubObject Object
    (
      [instance] => 2
    )

)
Cloned Object:
MyCloneable Object
(
  [object1] => SubObject Object
    (
      [instance] => 3
    )

  [object2] => SubObject Object
    (
      [instance] => 2
    )

)
cloneTest:
Class [ <user> class MyCloneable ] {
 @@ /public/t.php 18-33

 - Constants [0] {
 }

 - Static properties [0] {
 }

 - Static methods [0] {
 }

 - Properties [2] {
  Property [ <default> public $object1 ]
  Property [ <default> public $object2 ]
 }

 - Methods [2] {
  Method [ <user> public method __clone ] {
   @@ /public/t.php 23 - 27
  }

  Method [ <user> public method cloneTest ] {
   @@ /public/t.php 29 - 32
  }
 }
}

•對象遍歷: foreach只能遍歷對象的可見屬性,無法遍歷其方法,實現(xiàn)起來比較容易;另外,也可通過實現(xiàn)Iterator接口或IteratorAggregate接口的方法遍歷對象屬性。

•類型約束: PHP作為一種弱類型語言,類型約束可以讓編程更加規(guī)范,也少出些差錯;類型約束不只能用在對象定義中,也能用在函數(shù)定義中。類型約束可指定對象、接口、array、callable(閉包callback),類型約束用來保證實際數(shù)據(jù)類型與原型定義一致,不一致則拋出一個可捕獲的致命錯誤;不過如果定義了默認值為NULL,那么實參可以是NULL;類型約束不能用于標量類型如 int 或 string,Traits 也不允許。

•對象序列化與還原:函數(shù)serialize()可將打成包含字節(jié)流的字符串便于存儲對象,函數(shù)unserialize()能夠還原字符串為對象。但有一個前提是,無論序列化還是反序列化,對象的類定義已經(jīng)完成,即需要先導入類(文件)。

•重載:PHP的重載包括屬性和方法,更像一個套用說法,不支持常見的重載語法規(guī)范,具有不可預見性,影響范圍更寬泛,就是利用魔術方法(magic methods)來調用當前環(huán)境下未定義或不可見的類屬性或方法。所有重載方法都必須被聲明為 public(這一條應該比較好理解,別人可能因不可見才需要你,那你自己必須可見才行),參數(shù)也不能通過引用傳遞(重載方法具有不可預見性,估計出于安全方面的考慮吧,防止變量被隨意引用)。在除 isset() 外的其它語言結構中無法使用重載的屬性,這意味著當對一個重載的屬性使用 empty() 時,重載魔術方法將不會被調用; 為避開此限制,必須將重載屬性賦值到本地變量再使用 empty(),可見重載屬性是介于合法屬性與非法屬性之間的存在。

[屬性重載]:這些方法不能被聲明為 static,在靜態(tài)方法中,這些魔術方法將不會被調用
public void __set ( string $name , mixed $value )
在給不可訪問屬性賦值時,__set() 會被調用

public mixed __get ( string $name )
讀取不可訪問屬性的值時,__get() 會被調用

public bool __isset ( string $name )
當對不可訪問屬性調用 isset() 或 empty() 時,__isset() 會被調用

public void __unset ( string $name )
當對不可訪問屬性調用 unset() 時,__unset() 會被調用

Note:
因為 PHP 處理賦值運算的方式,__set() 的返回值將被忽略。類似的, 在下面這樣的鏈式賦值中,__get() 不會被調用:
 $a = $obj->b = 8;

[方法重載]:
public mixed __call ( string $name , array $arguments )
在對象中調用一個不可訪問方法時,__call() 會被調用

public static mixed __callStatic ( string $name , array $arguments )
在靜態(tài)上下文中調用一個不可訪問方法時,__callStatic() 會被調用

•靜態(tài)屬性和方法:static 關鍵字用來定義靜態(tài)屬性、靜態(tài)方法,靜態(tài)屬性不能通過實例化的對象-> 來訪問(但靜態(tài)方法可以)。靜態(tài)屬性只能被初始化為常量表達式,所以可以把靜態(tài)屬性初始化為整數(shù)或數(shù)組,但不能初始化為另一個變量或函數(shù)返回值,也不能指向一個對象??梢杂靡粋€變量表示類來動態(tài)調用靜態(tài)屬性,但該變量的值不能為關鍵字 self,parent 或 static。

 class Foo
 {
   public static $my_static = 'foo';
 
   public function staticValue() {
     return self::$my_static;
   }
 }
 
 class Bar extends Foo
 {
   public function fooStatic() {
     return parent::$my_static;
   }
 }
 
 
 print Foo::$my_static . "\n";
 
 $foo = new Foo();
 print $foo->staticValue() . "\n";
 print $foo->my_static . "\n";   // Undefined "Property" my_static 
 
 print $foo::$my_static . "\n";
 $classname = 'Foo';
 print $classname::$my_static . "\n"; // As of PHP 5.3.0
 
 print Bar::$my_static . "\n";
 $bar = new Bar();
 print $bar->fooStatic() . "\n";

•后期靜態(tài)綁定:static:: 定義后期靜態(tài)綁定工作原理是存儲了上一個“非轉發(fā)調用”(non-forwarding call)的類名。當進行靜態(tài)方法調用時,該類名即為明確指定的那個(通常在 :: 運算符左側部分);當進行非靜態(tài)方法調用時,即為該對象所屬的類。使用 self:: 或者 __CLASS__ 對當前類的靜態(tài)引用,取決于定義當前方法所在的類;static:: 不再被解析為定義當前方法所在的類,而是在實際運行時計算的,可以用于靜態(tài)屬性和所有方法的調用。

 <?php
 class A
 {
   
   private $proPrivate = "private of A";
   protected $proProtected = "protected of A";
   public $proPublic = "public of A";
   
   private function foo()
   {
     echo $this->proPrivate."\n";
     echo $this->proProtected."\n";
     echo $this->proPublic."\n";
   }
   
   public function test()
   {
     $this->foo();
     static::foo();
   }
 }
 
 class B extends A
 {
  /* foo() will be copied to B, hence its scope will still be A and
   * the call be successful */
 }
 
 class C extends A
 {
   private $proPrivate = "private of C";
   protected $proProtected = "protected of C";
   public $proPublic = "public of C";
   
   private function foo()
   {
     /* original method is replaced; the scope of the new one is C */
     echo "I am C\n";
   }
   
   public function myFoo()
   {
     //parent::foo();
     $this->foo();
   }
 }
 
 echo "Class B:\n";
 $b = new B();
 $b->test();
 echo "\nClass C:\n";
 $c = new C();
 $c->myFoo();
 $c->test();  //fails

上例輸出結果:

Class B:
private of A
protected of A
public of A
private of A
protected of A
public of A

Class C:
I am C
private of A
protected of C
public of C 
Fatal error: Uncaught Error: Call to private method C::foo() from context 'A' in /public/t.php:19 Stack trace: #0 /public/t.php(54): A->test() #1 {main} thrown in /public/t.php on line 19

•繼承:官方文檔對繼承有這樣一段描述“當擴展一個類,子類就會繼承父類所有公有的和受保護的方法。除非子類覆蓋了父類的方法,被繼承的方法都會保留其原有功能”,言下之意似乎私有屬性和方法不會被繼承;然而上例又告訴我們子類擁有與父類一致的屬性和方法,繼承就是全盤復制,這才能滿足我們對繼承編程的需求,如果私有的不能繼承,子類就必須自行重新定義,在大多數(shù)時候沒有必要。另外就是可見性問題,父類的私有屬性和方法在子類是不可見的。上例還告訴我們對象實際執(zhí)行的域要考慮可見性、繼承、后期靜態(tài)綁定機制。

相關文章

  • PHP SQLite類

    PHP SQLite類

    PHP SQLite類代碼。
    2009-05-05
  • PHP有序表查找之二分查找(折半查找)算法示例

    PHP有序表查找之二分查找(折半查找)算法示例

    這篇文章主要介紹了PHP有序表查找之二分查找(折半查找)算法,簡單介紹了二分查找法的概念、原理并結合實例形式分析了php基于二分查找算法進行有序線性表查找的相關操作技巧,需要的朋友可以參考下
    2018-02-02
  • 360通用php防護代碼(使用操作詳解)

    360通用php防護代碼(使用操作詳解)

    本篇文章是對360通用php防護代碼的使用操作步驟進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • centos下file_put_contents()無法寫入文件的原因及解決方法

    centos下file_put_contents()無法寫入文件的原因及解決方法

    下面小編就為大家?guī)硪黄猚entos下file_put_contents()無法寫入文件的原因及解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • php運行提示:Fatal error Allowed memory size內存不足的解決方法

    php運行提示:Fatal error Allowed memory size內存不足的解決方法

    這篇文章主要介紹了php運行提示:Fatal error Allowed memory size內存不足的解決方法,分別針對有服務器管理權限和沒有服務器管理權限的情況分析解決方法,是非常實用的技巧,需要的朋友可以參考下
    2014-12-12
  • php+mysql結合Ajax實現(xiàn)點贊功能完整實例

    php+mysql結合Ajax實現(xiàn)點贊功能完整實例

    這篇文章主要介紹了php+mysql結合Ajax實現(xiàn)點贊功能,以一個完整實例形式詳細分析了實現(xiàn)點贊功能中涉及的html頁面、Ajax功能及php方法的使用技巧,非常具有實用價值,需要的朋友可以參考下
    2015-01-01
  • php計算稅后工資的方法

    php計算稅后工資的方法

    這篇文章主要介紹了php計算稅后工資的方法,涉及php流程控制及數(shù)學運算的相關技巧,比較簡單實用,需要的朋友可以參考下
    2015-07-07
  • PHP Socket 編程

    PHP Socket 編程

    讓我們以一個簡單的例子開始---一個接收輸入字符串,處理并返回這個字符串到客戶端的TCP服務.
    2010-04-04
  • PHP獲取當前所在目錄位置的方法

    PHP獲取當前所在目錄位置的方法

    這篇文章主要介紹了PHP獲取當前所在目錄位置的方法,涉及getcwd(0函數(shù)的用法以及相關的PHP目錄操作函數(shù)的使用技巧,具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-11-11
  • php 安全過濾函數(shù)代碼

    php 安全過濾函數(shù)代碼

    php 安全過濾函數(shù)代碼,防止用戶惡意輸入內容。
    2011-05-05

最新評論