博客
关于我
php中的方法链
阅读量:120 次
发布时间:2019-02-26

本文共 836 字,大约阅读时间需要 2 分钟。

在许多流行的编程框架中,比如Zend、CakePHP等,人们常常使用如下的类方法调用方式:$obj->foo()->bar()->anotherMethod();。这其实是PHP中的方法链调用机制的应用。通过一个简单的例子,我们可以更好地理解这一点。

以下是一个完整的类定义示例:

class Person {    private $name;    private $age;    public function setName($Name) {        $this->name = $Name;        return $this; // 返回当前对象    }    public function setAge($Age) {        $this->age = $Age;        return $this; // 返回当前对象    }    public function findMe() {        echo "My name is " . $this->name . " and I am " . $this->age . " years old.";    }}

正常的调用方式如下:

$myself = new Person();$myself->setName('Arvind Bhardwaj');$myself->setAge('22');$myself->findMe();

而使用方法链的优化方式则可以简化为:

$myself = new Person();$myself->setName('Arvind Bhardwaj')->setAge('22')->findMe();

这种方法链的调用方式在PHP中被广泛应用,特别是在需要多次调用相关方法的情况下。它的核心原理是每个方法都返回当前对象(return $this;),从而允许方法链的连续调用。这种写法不仅简化了代码,也提高了代码的可读性和维护性。

转载地址:http://lrif.baihongyu.com/

你可能感兴趣的文章
MySQL集群解决方案(2):主从复制架构
查看>>
MySQL集群解决方案(3):MyCat中间件
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
MySQL集群解决方案(5):PXC集群
查看>>
MySQL面试宝典
查看>>
WAP短信:融合传统短信和互联网的新型通信方式
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>
mysql面试题:创建索引时会不会锁表?
查看>>
mysql面试题:高度为3的B+树可以存放多少数据?
查看>>
mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
查看>>
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用之——keepalived+互为主从
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>
MySQL高可用解决方案
查看>>
MySQL高可用解决方案详解
查看>>