这一节课讲的是方法重载,后期静态绑定的原理分析call_user_func_array()函数的应用以及实战,下面是案例:
代码
实例
<?php class Query {//保存sql语句中的各个组成部分 private $sql=[]; //数据库连接对象 private $pdo=null; //构造方法:连接数据库 public function __construct() { $this->pdo=new PDO('mysql:host=127.0.0.1;dbname=php','root','5201314'); } //table()获取sql语句的表名 public function table($table){ $this->sql['table']=$table; return$this; } // fields()获取sql语句的字段列表 public function fields($fields) { $this->sql['fields']=$fields; return $this; } // where()获取sql语句的查询条件 public function where($where) { $this->sql['where']=$where; return $this; } //执行查询 public function select() { $sql="select {$this->sql['fields']} from {$this->sql['table']} where {$this->sql['where']}"; $stmt=$this->pdo->prepare($sql); $stmt->execute(); return $stmt->fetchAll(PDO::FETCH_ASSOC); } }
运行实例 »
点击 "运行实例" 按钮查看在线实例
实例
<?php require 'Query.php'; class Db { public static function __callStatic($name, $arguments) { return call_user_func_array([(new Query()),$name],$arguments); } } $result=Db::table('staff') ->fields('staff_id,name,age,salary') ->where('salary > 8000') ->select(); echo '<pre>'; print_r($result);
运行实例 »
点击 "运行实例" 按钮查看在线实例
预览图
后期静态绑定的原理与使用场景分析
后期静态绑定工作原理是存储了在上一个“非转发调用”的类名。当进行静态方法调用时,该类名即为明确指定的那个(通常在 :: 运算符左侧部分);当进行非静态方法调用时,即为该对象所属的类。“后期绑定”的意思是说,static:: 不再被解析为定义当前方法所在的类,而是在实际运行时计算的。也可以称之为“静态绑定”,因为它可以用于(但不限于)静态方法的调用。
在非静态环境下,所调用的类即为该对象实例所属的类。由于 $this-> 会在同一作用范围内尝试调用私有方法,而 static:: 则可能给出不同结果。另一个区别是 static:: 只能用于静态属性。
后期静态绑定的解析会一直到取得一个完全解析了的静态调用为止。另一方面,如果静态调用使用 parent:: 或者 self:: 将转发调用信息。
总结
1、static 关键字的用途: 定义静态成员; 后期静态绑定
2、后期静态绑定:静态继承的上下文环境,用于动态设置静态方法的调用者
3、call_user_func_array():执行方法或回调函数
4、__call($method, $arguments): 当用户访问一个不存在或无权限的方法时调用,__callStatic($method, $arguments):当用户访问一个不存在或无权限的静态方法时调用