设为首页 收藏本站
查看: 945|回复: 0

[经验分享] PHP中this self parent三个应用说明

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-4-9 13:48:50 | 显示全部楼层 |阅读模式
this,self,parent三个关键字之间的区别。从字面上比较好理解,分别是指这、自己、父亲。我们先建立几个概念,这三个关键字分别是用在什么地方呢?我们初步解释一下,this是指向当前对象的指针(姑且用C里面的指针来看吧),self是指向当前类的指针,parent是指向父类的指针。我们这里频繁使用指针来描述,是因为没有更好的语言来表达。

      这么说还不能很了解,那我们就根据实际的例子结合来讲讲:

Php代码
(1) this   
  
class UserName   
{   
     //定义属性      
     private $name;   
  
     //定义构造函数   
     function __construct( $name )   
     {   
          $this->name = $name; //这里已经使用了this指针   
     }   
  
     //析构函数   
     function __destruct(){}   
  
     //打印用户名成员函数   
     function printName()   
     {   
         print( $this->name ); //又使用了this指针   
     }   
}   
  
//实例化对象   
$nameObject = new UserName( "heiyeluren" );   
  
//执行打印   
$nameObject->printName(); //输出: heiyeluren   
  
//第二次实例化对象   
$nameObject2 = new UserName( "PHP5" );   
  
//执行打印   
$nameObject2->printName(); //输出:PHP5   
?>   
  
我们看,上面的类分别在11行和20行使用了this指针,那么当时this是指向谁呢?其实this是在实例化的时候来确定指向谁,比如第一次实例化对象的时候(25行),那么当时this就是指向$nameObject对象,那么执行18行的打印的时候就把print( $this-><name )变成了print( $nameObject->name ),那么当然就输出了"heiyeluren"。第二个实例的时候,print( $this->name )变成了print( $nameObject2->name ),于是就输出了"PHP5"。所以说,this就是指向当前对象实例的指针,不指向任何其他对象或类。   
  
   
  
(2)self   
  
首先我们要明确一点,self是指向类本身,也就是self是不指向任何已经实例化的对象,一般self使用来指向类中的静态变量。   
  
<?php   
  
     class Counter   
     {   
         //定义属性,包括一个静态变量   
         private static $firstCount = 0;   
         private $lastCount;   
  
         //构造函数   
         function __construct()   
         {   
              $this->lastCount = ++selft::$firstCount; //使用self来调用静态变量,使用self调用必须使用::(域运算符号)   
         }   
  
         //打印最次数值   
         function printLastCount()   
         {   
              print( $this->lastCount );   
         }   
     }   
  
//实例化对象   
$countObject = new Counter();   
  
$countObject->printLastCount(); //输出 1   
  
?>   
  
我们这里只要注意两个地方,第6行和第12行。我们在第二行定义了一个静态变量$firstCount,并且初始值为0,那么在12行的时候调用了这个值,使用的是self来调用,并且中间使用"::"来连接,就是我们所谓的域运算符,那么这时候我们调用的就是类自己定义的静态变量$frestCount,我们的静态变量与下面对象的实例无关,它只是跟类有关,那么我调用类本身的的,那么我们就无法使用this来引用,可以使用 self来引用,因为self是指向类本身,与任何对象实例无关。换句话说,假如我们的类里面静态的成员,我们也必须使用self来调用。   
  
  
(3)parent   
  
我们知道parent是指向父类的指针,一般我们使用parent来调用父类的构造函数。   
  
<?php   
  
//基类   
class Animal   
{   
     //基类的属性   
     public $name; //名字   
  
     //基类的构造函数   
     public function __construct( $name )   
     {   
          $this->name = $name;   
     }   
}   
  
//派生类   
class Person extends Animal //Person类继承了Animal类   
{   
     public $personSex; //性别   
     public $personAge; //年龄   
  
     //继承类的构造函数   
     function __construct( $personSex, $personAge )   
     {   
          parent::__construct( "heiyeluren" ); //使用parent调用了父类的构造函数   
          $this->personSex = $personSex;   
          $this->personAge = $personAge;   
     }   
  
     function printPerson()   
     {   
          print( $this->name. " is " .$this->personSex. ",this year " .$this->personAge );   
      }   
}   
  
//实例化Person对象   
$personObject = new Person( "male", "21");   
  
//执行打印   
$personObject->printPerson(); //输出:heiyeluren is male,this year 21   
  
?>  

(1) this

class UserName
{
     //定义属性   
     private $name;

     //定义构造函数
     function __construct( $name )
     {
          $this->name = $name; //这里已经使用了this指针
     }

     //析构函数
     function __destruct(){}

     //打印用户名成员函数
     function printName()
     {
         print( $this->name ); //又使用了this指针
     }
}

//实例化对象
$nameObject = new UserName( "heiyeluren" );

//执行打印
$nameObject->printName(); //输出: heiyeluren

//第二次实例化对象
$nameObject2 = new UserName( "PHP5" );

//执行打印
$nameObject2->printName(); //输出:PHP5
?>

我们看,上面的类分别在11行和20行使用了this指针,那么当时this是指向谁呢?其实this是在实例化的时候来确定指向谁,比如第一次实例化对象的时候(25行),那么当时this就是指向$nameObject对象,那么执行18行的打印的时候就把print( $this-><name )变成了print( $nameObject->name ),那么当然就输出了"heiyeluren"。第二个实例的时候,print( $this->name )变成了print( $nameObject2->name ),于是就输出了"PHP5"。所以说,this就是指向当前对象实例的指针,不指向任何其他对象或类。



(2)self

首先我们要明确一点,self是指向类本身,也就是self是不指向任何已经实例化的对象,一般self使用来指向类中的静态变量。

<?php

     class Counter
     {
         //定义属性,包括一个静态变量
         private static $firstCount = 0;
         private $lastCount;

         //构造函数
         function __construct()
         {
              $this->lastCount = ++selft::$firstCount; //使用self来调用静态变量,使用self调用必须使用::(域运算符号)
         }

         //打印最次数值
         function printLastCount()
         {
              print( $this->lastCount );
         }
     }

//实例化对象
$countObject = new Counter();

$countObject->printLastCount(); //输出 1

?>

我们这里只要注意两个地方,第6行和第12行。我们在第二行定义了一个静态变量$firstCount,并且初始值为0,那么在12行的时候调用了这个值,使用的是self来调用,并且中间使用"::"来连接,就是我们所谓的域运算符,那么这时候我们调用的就是类自己定义的静态变量$frestCount,我们的静态变量与下面对象的实例无关,它只是跟类有关,那么我调用类本身的的,那么我们就无法使用this来引用,可以使用 self来引用,因为self是指向类本身,与任何对象实例无关。换句话说,假如我们的类里面静态的成员,我们也必须使用self来调用。


(3)parent

我们知道parent是指向父类的指针,一般我们使用parent来调用父类的构造函数。

<?php

//基类
class Animal
{
     //基类的属性
     public $name; //名字

     //基类的构造函数
     public function __construct( $name )
     {
          $this->name = $name;
     }
}

//派生类
class Person extends Animal //Person类继承了Animal类
{
     public $personSex; //性别
     public $personAge; //年龄

     //继承类的构造函数
     function __construct( $personSex, $personAge )
     {
          parent::__construct( "heiyeluren" ); //使用parent调用了父类的构造函数
          $this->personSex = $personSex;
          $this->personAge = $personAge;
     }

     function printPerson()
     {
          print( $this->name. " is " .$this->personSex. ",this year " .$this->personAge );
      }
}

//实例化Person对象
$personObject = new Person( "male", "21");

//执行打印
$personObject->printPerson(); //输出:heiyeluren is male,this year 21

?>



  


Php代码
成员属性都是public的,特别是父类的,是为了供继承类通过this来访问。我们注意关键的地方,第25行:   
parent::__construct( "heiyeluren"  
),这时候我们就使用parent来调用父类的构造函数进行对父类的初始化,因为父类的成员都是public的,于是我们就能够在继承类中直接使用   
this来调用。   
  
  
总结:   
this是指向对象实例的一个指针,self是对类本身的一个引用,parent是对父类的引用。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-362475-1-1.html 上篇帖子: XXTEA 加密算法的 JavaScript 和 PHP 实现 下篇帖子: web程序乱码深入分析【基础原理篇】--php为例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表