一、定义区别
get_called_class :返回后期静态绑定("Late Static Binding")类的名称
get_class :返回对象的类名
对于后期静态绑定的定义和理解,可以看我以前的一篇文章。
二、实例分析
demo1、
class A{
static public function cat()
{
var_dump(get_class());
var_dump(get_called_class());
}
}
class B extends A{
}
B::cat();
输出如下
![](https://img.haomeiwen.com/i4802023/71991f568498232e.png)
分析如下:
1、当执行B:cat()时,属于“非转发调用”,存储的是B
2、当执行到cat方法时,get_class输出当前类名 A,get_called_class,则输出“非转发调用”存储的B类名
demo2、
class A{
static public function cat()
{
var_dump(get_class());
var_dump(get_called_class());
}
}
class B extends A{
public static function dog(){
A::cat();
parent::cat();
}
}
B::dog();
输出如下
![](https://img.haomeiwen.com/i4802023/f4efe35e6b90a26f.png)
分析如下:
1、当执行B:dog时,当前是“非转发调用”,存储了B类名
2、执行到dog方法内部时,
2.1 A:cat是“非转发调用”,存储了A,故执行到A中的cat方法时,get_class只是输出当前类名A,get_called_class则是输出"非转发调用"存储的A,所以 输出 两个A
2.2 parent:cat是"转发调用",当前没有进行存储,故“非转发调用”存储的还是B,所以执行到A中的cat方法时,输出 A 和 B
demo3、
<?php
class A
{
public function cc(){
var_dump(get_class());
var_dump(get_called_class());
}
}
class B extends A{
public function bb(){
$this->cc();
}
}
class C extends B{
}
$c = new C();
$c->bb();
输出如下:
![](https://img.haomeiwen.com/i4802023/09d1261e17829823.png)
分析如下:
1、当执行c->bb()时,当前是“非转发调用”,存储的是C
2、当执行bb方法时,内部的$this->cc是,“转发调用”,不进行存储
3、执行到A类中的cc方法时,get_class输出当前类A,get_called_class输出“非转发调用”存储的C
网友评论