7.7.13 PHP 5.3以后新增的魔術方法
魔術方法__invoke()
在創建實例后,可以直接調用對象
class testClass {
public function __invoke {
echo “hello world”;
}
}
$n = new testClass;
$n();
執行結果為: hello world。
魔術方法__callStatic()
它的工作方式類似于 __call() 魔術方法,__callStatic() 是為了處理靜態方法調用,它必須是公共的,并且必須被聲明為靜態的。
class A
{
public function __call($name, $args)
{
}
public static function __callStatic($name, $args)
{
}
}
test.php
<?php
/*
* 魔術方法, 只有PHP語言中存在
*
*
* __construct()
*
* __destruct()
*
* __set()
*
* __get()
*
* __isset()
*
* __unset()
*
* 1. 自動調用, 但不同的魔術方法,有自己的調時機
* 2. 都是以"__"開始的方法
* 3. 所有的魔術方法,方法名都是固定的
* 4. 如果不寫, 就不存在, 也就沒有默認的功能
*
*
*
* __toString()
*
* 1. 是在直接使用 echo print printf輸出一個對象引用時,自動調用這個方法
* 2. 將對象的基本信息放在__toString()方法內部, 形成自字符串返回。
* 3. __toString()方法中, 不能有參數, 而且必須返回一個字符串
*
*
* 克隆對象
* 1. 使用clone這個關鍵 復制了一個對象
*
*
* __clone()魔術方法
*
* 1. 是在克隆對象時,自動調用的方法
* 2. 作用:和構造方法一樣, 是對新克隆的對象進行初使化
* 3. 在這個方法中$this代表的是副本, 所以就可以給所有副本的成員初使化
*
* __call()
*
* 1. 就是在調用一個對象中不存的方法時,自動調用的方法
* 2. 有兩個參數, 第一個參數是, 調用的不存的方法的方法名, 第二個參數是,調用這個不存的方法的方法參數
* 3. 作用:可以寫提示,但這個不是主要的功能。 將方法的功能相似, 但方法名還要不同的, 就可以采用這個方式來完成
*
* 串行化(序列化)
*
* 1. 將對象轉成字符串(不用看懂) --- 串行化
*
* __sleep() -- 在串行化時自動調用的方法
*
* 作用: 可以設置需要串行化的對象的屬性
*
* 只要在這個方法中, 返回一個數組, 在數組中聲明了那個屬性名, 那個屬性就會被串行化, 沒有在這個數組中的就不被串行化。 默認這個方法, 全部屬性都串行化
*
*
*
* 2. 將字符串轉回對象 --- 返串行化
*
* __wakeup() --- 在返串行化時自動調用的方法
*
*
*
* 作用:對象串行化回來的對象,進行初使化用的和下面兩個方法作用相似
*
* __construct()
* __clone()
*
* *
* 注意(串行化的時機):
*
* 1. 將對象在網絡中傳輸
* 2. 將對象持久保存
*
*
* 數組串行化 json --- javascript object
*
*
* 1. eval()函數 --- 檢查并執行PHP代碼
*
* $str = "echo 'abc';";
eval($str);
var_dump();
var_export();
__set_state() 方法 , 就是在使用var_export()方法時, 導出一個類的信息時自動調用的方法
__invoke()方法, 是在對象實例之后, 直接像變量函數一樣調用時, 自動調用這個方法
*
*/
class Person {
public $name;
public $age;
public $sex;
public $marr = array("aaa", "bbb", "ccc", "ddd", "www");
function __construct($name, $age, $sex) {
$this->name = $name;
$this->age = $age;
$this->sex = $sex;
}
function say() {
echo "我的名子是:{$this->name},我的年齡是:{$this->age},我的性別是:{$this->sex}。<br>";
}
function __toString() {
return "aaaaaaaaaaaaaaaaaaa<br>";
}
function __destruct() {
echo "{$this->name} ###########<br>";
}
function __clone() {
$this->name="克隆的";
$this->age=0;
}
function __call($method, $args) {
if(in_array($method, $this->marr)) {
echo $args[0]."<br>";
}else{
echo "你調用的方法{$method}()不存在!<br>";
}
}
static function __callstatic($method, $args) {
echo "你調用的靜態方法$method(".implode(",", $args).")不存在";
}
function __sleep() {
echo "只串行化,name和age <br>";
return array("name", "age");
}
function __wakeup() {
echo "返串行化時自動調用我這個方法了<br>";
$this->age = 12;
}
static function __set_state($arr) {
$p = new Person("李四", 30, "女");
$p->name=$arr['name'];
$p->age = $arr['age'];
return $p;
}
function __invoke($a, $b, $c) {
echo "在對象引用后加上()調用時自動調用這個方法{$a}=={$b}=={$c}<br>";
}
/*
function aaa($a) {
echo $a;
}
function bbb($b) {
echo $b;
}
function ccc($c) {
echo $c;
}
function ddd($d) {
echo $d;
}
*/
}
$p = new Person("張三", 20, "男");
$p(1, 2, 4);
Person::hello(1,2,3);
$p->world(1,2,3);