<?php class baseClass {} class subClass extends baseClass{} interface aInterface {} class aClass implements aInterface {} $a = new baseClass(); var_dump( ($a instanceof baseClass)); //true $b = new subClass(); var_dump( ($b instanceof baseClass)); //true $c = new aClass(); var_dump( ($c instanceof aInterface)); //true ?>
注:使用 instanceof 时 不能是类名对类名,而是实例化名对类名 php
对于PHP面向对象, 类中的方法的参数能够是对象,在传对象的过程当中任何类的对象均可以传进去,可是不一样的对象传入到此方法后效果不一样,好比此方法用一个对象能够调用这个对象 的方法,可是若是传入的对象没有此方法,那就会报错,由于根本就没有你调用的方法啊,因此传入的对象是要有判断的。 性能
曾经咱们讲过一个解决方法,那就是把方法的参数类型肯定,对象参数也要指定对象类型便可,可是今天讲的是instanceof运算符来保障代码正常运行, 用instanceof运算符能够在方法里面判断,性能更好,下面是一个运用instanceof运算符的例子和没用时的比较。 this
没用instanceof运算符判断就会报错,示例代码以下: spa
<?php code
class User{ orm
private $name="zhenlw"; 对象
public function getName(){ 继承
return "UserName is ".$this->name; 接口
} get
}
class NormalUser extends User {
private $age = 99;
public function getAge(){
return "age is ".$this->age;
}
}
class UserAdmin{ //操做.
public static function getUserInfo(User $user){
echo $user->getAge();
}
}
$User = new User();
UserAdmin::getUserInfo($User);
?>
运行后报以下错误:
Fatal error: Call to undefined method User::getAge() in D:xampphtdocstest8test.php on line 20
由于你传入的对象参数根本没有getAge方法,若是是NormalUser的对象的话就能够正常运行了,这个时候咱们运用instanceof运算符来进行判断,修改后的示例代码以下:
<?php
class User{
private $name="zhenlw";
public function getName(){
return "UserName is ".$this->name;
}
}
class NormalUser extends User {
private $age = 99;
public function getAge(){
return "age is ".$this->age;
}
}
class UserAdmin{ //操做.
public static function getUserInfo(User $user){
if($user instanceof NormalUser){
echo $user->getAge();
} elseif($user instanceof User){
echo $user->getName();
}
}
}
$User = new User(); // 这里是User的对象.
UserAdmin::getUserInfo($User);
echo "<br>";
$normaluser = new NormalUser(); // 这里是NormalUser的对象.
UserAdmin::getUserInfo($normaluser);
?>
运行结果:
UserName is zhenlw
age is 99
看到运行结果就知道了吧,运用instanceof判断数据类型后就能够保证代码的健壮性,不论你传入的是哪一个对象,均可以正确的对此对象进行处理。