PHP面向对象之旅:parent::关键字

使用parent::来引用父类的方法
服务器君一共花费了235.217 ms进行了6次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

PHP5中使用parent::来引用父类的方法。

  • parent:: 可用于调用父类中定义的成员方法。
  • parent::的追溯不仅于直接父类。

通过parent::调用父类方法

<!-- 声明一个员工类,经理类继承自员工类 -->
<?
class employee{
	protected  $sal=3000;		
	public function getSal(){
		$this->sal = $this->sal + 1200;		
		return $this->sal ;
	}	
}
class Manager extends employee {
	//如果想让经理在员工工资的基础上多发1500元.
	//必须先调用父类的getSal()方法.
	public function getSal(){		
		parent::getSal();// 这里调用了父类的方法.
		$this->sal = $this->sal + 1500;		
		return $this->sal ;
	}	
}
$emp = new employee();
echo "普通员工的工资是 " . $emp->getSal();
echo "<br>";
$manager = new Manager();
echo "经理的工资是: " . $manager->getSal();
?>

程序运行结果:

普通员工的工资是 4200
经理的工资是: 5700

父类的private属性

这个东西解释起来十分的不爽。

Private属性是不能被继承的,如果父类有私有的属性。那么父类的方法只为父类的私有属性服务。

下面的例子看起来很奇怪,在子类中重新定义了一个属性$sal,系统却返回了父类的属性。

<?
class employee{
	private  $sal=3000;
	//protected    $sal=3000;
	public function getSal(){		
		return $this->sal;
	}		
}
class Manager extends employee {
	protected  $sal=5000;
	
	public function getParentSal(){
		//这里返回的是父类的private属性.
		return parent::getSal();
	}	
}
$manager = new Manager();
echo "PHP ".phpversion()."<br>";
echo $manager->getSal();
echo "<br>";
echo "parent's \$sal ".$manager->getParentSal();
?>

程序运行结果:

PHP 5.2.9
3000
parent's $sal 3000

如果父类中的属性被子类重写了。结果是这样的。注意 第5行的属性定义变成了protected。

<?
class employee{
	//private  $sal=3000;
	protected    $sal=3000;
	public function getSal(){		
		return $this->sal;
	}		
}
class Manager extends employee {
	protected  $sal=5000;
	
	public function getParentSal(){
		//这里返回的是父类的private属性.
		return parent::getSal();
	}	
}
$manager = new Manager();
echo "PHP ".phpversion()."<br>";
echo $manager->getSal();
echo "<br>";
echo "parent's \$sal ".$manager->getParentSal();
?>

程序运行结果:

PHP 5.2.9
5000
parent's $sal 5000

子类中重写的方法对当前private有效。

<?
class employee{
	private   $sal=3000;
	public function getSal(){		
		return $this->sal;
	}	
}
class Manager extends employee {
	private   $sal=5000;
	//重写过的方法
	public function getSal(){		
		return $this->sal;
	}		
	public function getParentSal(){
		//这里返回的是父类的private属性.
		return parent::getSal();
	}	
}
$manager = new Manager();
echo "PHP ".phpversion()."<br>";
echo $manager->getSal();
echo "<br>";
echo "parent's \$sal ".$manager->getParentSal();
?>

程序运行结果:

PHP 5.2.9
5000
parent's $sal 3000

打开zend调试状态看看,内存中的情况。注意最下面,有两个$sal 。分别是 3000 和 5000 。

<?
class employee{
	private  $sal=3000;	
	public function getSal(){		
		return $this->sal;
	}		
}
class Manager extends employee {
	protected  $sal=5000;	
	public function getParentSal(){
		return $this->sal;
	}	
}
$manager = new Manager();
echo "PHP ".phpversion()."<br>";
echo $manager->getSal();
?>

程序运行结果:

PHP 5.2.9
3000

将父类的属性$sal 改成 protected ,子类重写了父类的属性。在内存中只有一个 $sal 。

<?
class employee{
	protected  $sal=3000;	
	public function getSal(){		
		return $this->sal;
	}		
}
class Manager extends employee {
	protected  $sal=5000;	
	public function getParentSal(){
		return $this->sal;
	}	
}
$manager = new Manager();
echo "PHP ".phpversion()."<br>";
echo $manager->getSal();
?>

程序运行结果:

PHP 5.2.9
5000

如果你学过java,你会觉得这一切都是很难理解的。

在Java中当子类被创建时,父类的属性和方法在内存中都被创建,甚至构造函数也要被调用。

PHP5不是这样,PHP5调用父类用的是parent:: 而不是 parent-> ,这足以说明PHP5不想在内存中让父类也被创建。PHP5想让继承变的比Java更简单。

适应下就好。

这样调用会让PHP5.1.1溢出。新版不知道有没有问题。

<?
class employee{
	private   $sal=3000;
	public function getSal(){		
		return parent::$this->sal;
	}		
}
class Manager extends employee {
	protected  $sal=5000;
	public function getSal(){		
		return parent::$this->getSal();
	}	
}
$manager = new Manager();
echo "PHP ".phpversion()."<br>";
echo $manager->getSal();
?>

第12行改成这样就好了。注意比较。

return parent:: getSal();

这样的代码引起了递归操作,子类调用父类的方法,父类又调用子类方法。

return parent::$this->getSal();

延伸阅读

此文章所在专题列表如下:

  1. PHP面向对象之旅:类和对象
  2. PHP面向对象之旅:类的属性
  3. PHP面向对象之旅:类的方法
  4. PHP面向对象之旅:对象的比较
  5. PHP面向对象之旅:构造函数
  6. PHP面向对象之旅:类的继承
  7. PHP面向对象之旅:访问控制
  8. PHP面向对象之旅:方法覆盖
  9. PHP面向对象之旅:this关键字
  10. PHP面向对象之旅:parent::关键字
  11. PHP面向对象之旅:再谈重载
  12. PHP面向对象之旅:获取用户数据
  13. PHP面向对象之旅:用户权限管理类
  14. PHP面向对象之旅:static变量与方法
  15. PHP面向对象之旅:单例模式
  16. PHP面向对象之旅:final类和方法
  17. PHP面向对象之旅:PHP中的常量
  18. PHP面向对象之旅:抽象类
  19. PHP面向对象之旅:抽象方法
  20. PHP面向对象之旅:抽象类继承抽象类
  21. PHP面向对象之旅:静态抽象方法
  22. PHP面向对象之旅:模板模式
  23. PHP面向对象之旅:接口与抽象方法
  24. PHP面向对象之旅:接口的实现
  25. PHP面向对象之旅:接口的继承
  26. PHP面向对象之旅:类型提示
  27. PHP面向对象之旅:PHP的多态
  28. PHP面向对象之旅:instanceof运算符
  29. PHP面向对象之旅:接口与组合模拟多继承
  30. PHP面向对象之旅:一个接口实例
  31. PHP面向对象之旅:简单工厂模式

本文地址:http://www.nowamagic.net/librarys/veda/detail/1091,欢迎访问原出处。

不打个分吗?

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/1091

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《代码整洁之道》 马丁(Robert C. Martin) (作者), 韩磊 (译者)

软件质量,不但依赖于架构及项目管理,而且与代码质量紧密相关。这一点,无论是敏捷开发流派还是传统开发流派,都不得不承认。《代码整洁之道》提出一种观念:代码质量与其整洁度成正比。干净的代码,既在质量上较为可靠,也为后期维护、升级奠定了良好基础。作为编程领域的佼佼者,《代码整洁之道》作者给出了一系列行之有效的整洁代码操作实践。这些实践在《代码整洁之道》中体现为一条条规则(或称“启示”),并辅以来自现实项目的正、反两面的范例。只要遵循这些规则,就能编写出干净的代码,从而有效提升代码质量。

更多计算机宝库...