PHP5.0對象模型探索之對象串行化

串行化可以把變量包括對象,轉化成連續bytes數據,你可以將串行化後的變量存在一個文件裡或在網絡上傳輸,然後再反串行化還原為原來的數據。你在反串行化類的對象之前定義的類,PHP可以成功地存儲其對象的屬性和方法. 有時你可能需要一個對象在反串行化後立即執行。為瞭這樣的目的,PHP會自動尋找__sleep和__wakeup方法。 

  當一個對象被串行化,PHP會調用__sleep方法(如果存在的話). 在反串行化一個對象後,PHP 會調用__wakeup方法. 這兩個方法都不接受參數. __sleep方法必須返回一個數組,包含需要串行化的屬性. PHP會拋棄其它屬性的值。如果沒有__sleep方法,PHP將保存所有屬性。 

  例子1顯示瞭如何用__sleep和__wakeup方法來串行化一個對象. Id屬性是一個不打算保留在對象中的臨時屬性. __sleep方法保證在串行化的對象中不包含id屬性. 當反串行化一個User對象,__wakeup方法建立id屬性的新值. 這個例子被設計成自我保持. 在實際開發中,你可能發現包含資源(如圖像或數據流)的對象需要這些方法。 

  Listing1 Object serialization 

class User 

 public $name; 
 public $id; 

 function __construct() 
 { 
  //give user a unique ID 賦予一個不同的ID 
  $this->id = uniqid(); 
 } 

 function __sleep() 
 { 
  //do not serialize this->id 不串行化id 
  return(array(“name”)); 
 } 

 function __wakeup() 
 { 
  //give user a unique ID 
  $this->id = uniqid(); 
 } 


//create object 建立一個對象 
$u = new User; 
$u->name = “Leon”; 

//serialize it 串行化 註意不串行化id屬性,id的值被拋棄 
$s = serialize($u); 

//unserialize it 反串行化 id被重新賦值 
$u2 = unserialize($s); 

//$u and $u2 have different IDs $u和$u2有不同的ID 
print_r($u); 
print_r($u2); 
?> 

發佈留言