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);