当前位置:首页 » 《随便一记》 » 正文

php 之魔术方法详解

27 人参与  2023年04月02日 15:45  分类 : 《随便一记》  评论

点击全文阅读


✨ 目录

? 构造方法 / __construct? 析构方法 / __destruct? 克隆方法 / __clone? 非静态调用方法 / __call? 静态调用方法 / __callStatic? 打印方法 / __debugInfo? 获取成员属性 / __get? 获取不可访问属性 / __isset? 属性赋值 / __set? 调用对象本身 / __invoke? 序列化调用 / __sleep? 反序列化调用 / __wakeup? 输出字符调用 / __toString? 删除调用 / __unset

? 构造方法 / __construct

当类被实例化的时候就会调用简单来说,就是 new 一个类的时候,这个方法就会自动执行
<?phpclass autofelix {    public function __construct()    {        echo '我是飞兔小哥~';    }}new autofelix();

? 析构方法 / __destruct

当类被销毁时候自动触发可以使用 unset 方法触发该方法
<?phpclass autofelix {    public function __destruct()    {        echo '我是飞兔小哥,别销毁我~';    }}unset(new autofelix());

? 克隆方法 / __clone

当类被克隆时自动会自动调用
<?phpclass autofelix {    public function __clone()    {        echo '我是飞兔小哥,我想克隆你~';    }}$a = new autofelix();clone $a;

? 非静态调用方法 / __call

当要调用的方法不存在或者权限不足时候会自动调用比如我在类的外部调用类内部的 private 修饰的方法
<?phpclass autofelix {    private function say()     {        echo '我是飞兔小哥~';    }    public function __call($name, $arguments)    {        echo '你无权调用' . $name . '方法';        die;    }}(new autofelix())->say();

? 静态调用方法 / __callStatic

当要调用的静态方法不存在或者权限不足时候会自动调用比如我在类的外部调用类内部的 private 修饰的静态方法
<?phpclass autofelix {    private static function say()     {        echo '我是飞兔小哥~';    }    public function __callStatic($name, $arguments)    {        echo '你无权调用' . $name . '方法';        die;    }}$a = new autofelix();$a::say();

? 打印方法 / __debugInfo

该方法会在 var_dump() 类对象时候被调用如果没有定义该方法,var_dump() 将会打印出所有的类属性
<?phpclass autofelix {    public function __debugInfo()    {        echo '飞兔小哥给你温馨提示';    }}var_dump(new autofelix());

? 获取成员属性 / __get

通过它可以在对象外部获取私有成员属性
<?phpclass autofelix {    private $name = '飞兔小哥';    public function __get($name)    {        if(in_array($name, ['name', 'age'])) {           echo $this->name;        } else {            echo '不是什么东西都能访问的~';        }    }}(new autofelix())->name;

? 获取不可访问属性 / __isset

当对不可访问的属性调用 isset() 或则会 empty() 时候会被自动调用
<?phpclass autofelix {    private $name = '飞兔小哥';    public function __isset($name)    {        if(in_array($name, ['name', 'age'])) {           echo $this->name;        } else {            echo '不是什么东西都能访问的~';        }    }}isset(new autofelix()->name);

? 属性赋值 / __set

给一个未定义的属性赋值时候会被触发
<?phpclass autofelix {    public function __set($name, $value)    {        echo '你想给' . $name . '赋值' . $value;    }}(new autofelix())->name = '飞兔小哥';

? 调用对象本身 / __invoke

对象本身不能直接当函数用如果对象被当作函数调用就会触发该方法
<?phpclass autofelix {    public function __invoke()    {        echo '你想调用我?';    }}(new autofelix())();

? 序列化调用 / __sleep

当在类的外部调用 serialize() 时会自动被调用
<?phpclass autofelix {    public function __sleep()    {        echo '我是飞兔小哥~';    }}serialize(new autofelix());

? 反序列化调用 / __wakeup

当执行 unserialize() 方法时会被自动调用
<?phpclass autofelix {    public function __wakeup()    {        echo '我是飞兔小哥~';    }}unserialize(new autofelix());

? 输出字符调用 / __toString

当一个类被当作字符串处理时应该返回什么这里必须返回一个 string 类型不然会报致命错误
<?phpclass autofelix {    public function __toString()    {        return '我是你得不到的对象...';    }}$a = new autofelix();echo $a;

? 删除调用 / __unset

当对不可访问的属性调用 unset() 时会被自动调用
<?phpclass autofelix {    private $name = '飞兔小哥';    public function __unset($name)    {        echo '别删我,我是你兔哥';    }}$a = new autofelix();unset($a->name);

点击全文阅读


本文链接:http://zhangshiyu.com/post/58034.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1