PHP中自我关键字的案例分析

  介绍

这篇文章主要介绍了PHP中自我关键字的案例分析,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

PHP群里有人询问自我<代码> 关键字的用法,答案是比较明显的:静态成员函数内不能用<代码> 调用非成员函数,但可以用<代码> 自我调用静态成员函数/变量/常量;其他成员函数可以用<代码> 自我调用静态成员函数以及非静态成员函数。随着讨论的深入,发现自我<代码> 并没有那么简单。鉴于此,本文先对几个关键字做对比和区分,再总结<代码>自我>

与<代码>父,<代码>静态> 的区别

要想将彻底搞懂<代码>自我> ,<代码>静态> 区分开。以下分别做对比。

<代码>父

<代码>自我与<代码> 的母公司区分比较容易:<代码> 引父母用父类/基类被隐盖的方法(或变量),<代码>自我> 阶级基础{   公共函数__construct () {   回声“基地contructor !“, PHP_EOL;   }   }      类孩子{   公共函数__construct () {   父:__construct ();   回声“孩子contructor !“, PHP_EOL;   }   }      新的子;//输出://基地contructor !//子contructor !

<代码>静态代码

<代码>静态代码常规用途是修饰函数或变量使其成为类函数和类变量,也可以修饰函数内变量延长其生命周期至整个应用程序的生命周期。但是其与自我<代码> 关联上是PHP 5.3以来引入的新用途:静态延迟绑定。

有了<代码>静态> 阶级基础{   公共函数__construct () {   回声“基础构造函数!“,PHP_EOL;   }      公共静态函数getSelf () {   返回新自我();   }      公共静态函数getInstance () {   返回新的静态();   }      公共函数selfFoo () {   返回self:: foo ();   }      公共函数staticFoo () {   返回静态:foo ();   }      公共函数thisFoo () {   返回$ this→foo ();   }      公共函数foo () {   回声“基地Foo !“, PHP_EOL;   }   }      类儿童扩展基{   公共函数__construct () {   回声“孩子构造函数!“,PHP_EOL;   }      公共函数foo () {   回声“孩子Foo !“, PHP_EOL;   }   }      $基?孩子:getSelf ();   孩子=美元:getInstance ();      孩子→美元selfFoo ();   孩子→美元staticFoo ();   孩子→美元thisFoo ();

程序输出结果如下:

基础构造函数!   孩子构造函数!   基地Foo !   孩子Foo !   孩子Foo !

在函数引用上,selfstatic的区别是:对于静态成员函数,self指向代码当前类,static指向调用类;对于非静态成员函数,self抑制多态,指向当前类的成员函数,static等同于this,动态指向调用类的函数。

parentselfstatic三个关键字联合在一起看挺有意思,分别指向父类、当前类、子类,有点“过去、现在、未来”的味道。

this

selfthis是被讨论最多,也是最容易引起误用的组合。两者的主要区别如下:

  1. this不能用在静态成员函数中,self可以;
  2. 对静态成员函数/变量的访问,建议self,不要用$this::$this->的形式;
  3. 对非静态成员变量的访问,不能用self,只能用this;
  4. this要在对象已经实例化的情况下使用,self没有此限制;
  5. 在非静态成员函数内使用,self抑制多态行为,引用当前类的函数;而this引用调用类的重写(override)函数(如果有的话)。

self的用途

看完与上述三个关键字的区别,self的用途是不是呼之即出?一句话总结,那就是:self总是指向“当前类(及类实例)”。详细说则是:

PHP中自我关键字的案例分析