首页 后端开发 php教程 php类abstract和final,类方法abstract和final, interface

php类abstract和final,类方法abstract和final, interface

Jun 23, 2016 pm 01:26 PM

class类修饰符

final:

当final作用于某个类时,此类被限定为不可继承类,即其他类无法继承此类,最终类,当你不想让别人继承自己的编写的类时只需要在前面加上final关键字即可

final class MyClass {    //code}//fatal error final class MyClass can not be inherited by other classclass SubClass extends Myclass {}
登录后复制

当final作用于某个类方法时,此方法被限定为不可重写,即子类中不可以重写此方法,并非不可继承,类方法可否被继承依旧被public protected private限定,final method只是限定子类不可重写此方法,即便父类此方法为private无法被子类继承,子类中仍然不能重写此方法,即php的继承机制是先检查此方法是不是final,若为final子类中仍重写此方法,则报错,只有在不是final时才会进一步依据public protected private来限定子类是否能继承此方法

class MyClass {    final public function finalPublic() {        echo __METHOD__;    }        final private function finalPrivate() {        echo __METHOD__;    }        final protected function finalProtected () {        echo __METHOD__;    }}//可调用父类可继承的方法MyClass::finalPublic() MyClass::finalProtected() MyClass::finalPrivate()将不被继承class CorrectSubClass extends Myclass {}//因为重写了父类的final修饰的方法 所以会报错class ErrorSubClass extends Myclass {    public function finalPublic() {        echo __METHOD__;    }    //虽然并不能从父类MyClass中继承finalPrivate()方法但依旧会因为其被final修饰而报错    private function finalPrivate() {        echo __METHOD__;    }        protected function finalProtected () {        echo __METHOD__;    }}
登录后复制


abstract:

当abstract作用于某个类时,此类被限定为抽象类,只能用于继承,而无法实例化对象。

抽象类不一定含有抽象方法,但抽象方法一定存在于抽象类中,且继承此抽象类的子类必须全部实现其抽象方法,否则,子类也要标识为抽象类。

抽象方法是必须被子类继承实现的,所以不可以用private修饰符去限定abstract抽象方法,可以用public和protected去修饰。

abstract class MyClass {    //抽象方法的定义类似于C/C++中的函数声明 没有函数体 其后继承此类的子类中必须实现此方法 否则子类也必须为抽象类    abstract public function abstractFunc();    abstract public function abstractFuncOther();        public function index() {        }}abstract class SubAbstract extends MyClass {    //不实现父抽象类的抽象方法则自身必须为抽象类}//否则要实现全部抽象方法class Sub extends MyClass {    //继承抽象类若自身不为抽象类必须实现其父类的所有抽象方法    public function abstractFunc() {            }        public function abstractFuncOther() {            }}
登录后复制

实例汇总

<?php//========================================================================================================================================//============================================       final类       and      final方法       ==============================================/*** final class 不可以被其他类继承 终结类*/final class FinalClass{	public function index()	{		echo "i am " . __METHOD__;	}}/** * 含有final method的class 继承类中不能重写此类中的final method  * final的优先级要高于private 即虽然此类中此方法为final private method 子类无法继承此private方法 * 但此时依然会因为父类中此私有的方法为final 不能在子类中自行定义 不给你 也不让你做一个 */class FinalMethod{	final public function finalPublic()	{		echo __METHOD__ . ' can be inherited, but be overrided' . '<br/>';	}	final protected function fianlProtected()	{		echo __METHOD__ . ' can be inherited, but be overrided' . '<br/>';	}	final private function finalPrivate()	{		echo __METHOD__ . ' can not be inherited or be overrided' . '<br/>';	}}class MethodClass extends FinalMethod {	public function index()	{		$this->finalPublic();		$this->fianlProtected();	}	//被final限定不可重写父类所有的fianl方法 无论是否可从父类继承	// public function finalPrivate() {	// }}echo '==================== final ======================' . '<br/>';$method = new MethodClass();$method->index();//========================================================================================================================================//============================================       抽象类       and      抽象方法       ================================================/** * 抽象类 只能用于继承 不可实例化对象 且抽象类抽象方法可为零 * 抽象方法必须存在于抽象类中 抽象方法没有函数体 类似于c/c++中的函数声明 * 继承此抽象类的子类要么将此类中的所有抽象方法实现 否则子类也必须为抽象类 * 抽象方法不可以用private去修饰 因为其本身的出发点就是要去被重写实现的 这点与final恰好相反 final不允许被重写 abstract必须被重写 所以在抽象类中private没有任何意义 * 抽象方法的访问级别只能是public或者protected 且子类去实现方法时只能是降低方法的访问级别而不能提升 即protected可以被重写为public 但public不能重写为protected * 访问级别的升降要以顶级抽象方法的声明为准则 即使此方法后期被实现后又被继承 继承时重写次方法仍然不能提高访问级别 只能是降低 始终降低 */abstract class AbstractClass{	//index()被调用之日此抽象类的全部抽象方法肯定已被实现 index()只能通过对象去调用 而实例化对象时则此类的所有抽象方法最终也已被实现	public function index()	{		$this->abstractPublicFunc();		$this->abstractProtectedFunc();	}	// 不可以用private去修饰 abstract本来就是用于子类继承实现的 且子类实现此抽象方法时访问级别必须要小于等于此抽象类定义的	abstract public function abstractPublicFunc();	abstract protected function abstractProtectedFunc();}/** * 只实现了父抽象类中的一个抽象方法 则自身也只能作为抽象类使用 */abstract class SubAbstractClass extends AbstractClass{	//抽象方法被具体实现 但后续子类中此方法的访问级别仍然不能提升 即不能重写为protected	public function abstractPublicFunc()	{		echo __CLASS__ . __METHOD__ . '<br/>';	}}/** * 父类中的抽象方法都已经被实现 可实例化对象 */class ObjectClass extends SubAbstractClass{	public function abstractPublicFunc()	{		echo __METHOD__ . '<br/>';	}	//这里可以将此方法的访问级别设定为public 但绝对不可能为private	public function abstractProtectedFunc()	{		echo __METHOD__ . '<br/>';	}}echo '====================abstract=====================' . '<br/>';$abstract = new ObjectClass();$abstract->index();//========================================================================================================================================//========================================================       接口 interface       ====================================================/** * 接口是用来定义一套行为标准 任何使用此接口的类都必须追寻接口所声明的方法标准 是一套不需要使用abstract修饰的但全部为抽象方法的标准类 */interface MyInterface{	public function getName();	public function getAge();	public function getSex();}class User implements MyInterface{	private $name = null;	private $age = null;	private $sex = null;	public function __construct($name, $age, $sex)	{		$this->name = $name;		$this->age = $age;		$this->sex = $sex;	}	public function getName()	{		echo $this->name . '<br/>';	}	public function getAge()	{		echo $this->age . '<br/>';	}	public function getSex()	{		echo $this->sex . '<br/>';	}}$user = new User('sallency', 25, 'male');echo '====================interface=====================' . '<br/>';$user->getName();$user->getAge();$user->getSex();?>
登录后复制



本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP记录:PHP日志分析的最佳实践 PHP记录:PHP日志分析的最佳实践 Mar 10, 2025 pm 02:32 PM

PHP日志记录对于监视和调试Web应用程序以及捕获关键事件,错误和运行时行为至关重要。它为系统性能提供了宝贵的见解,有助于识别问题并支持更快的故障排除

在Laravel中使用Flash会话数据 在Laravel中使用Flash会话数据 Mar 12, 2025 pm 05:08 PM

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

php中的卷曲:如何在REST API中使用PHP卷曲扩展 php中的卷曲:如何在REST API中使用PHP卷曲扩展 Mar 14, 2025 am 11:42 AM

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

简化的HTTP响应在Laravel测试中模拟了 简化的HTTP响应在Laravel测试中模拟了 Mar 12, 2025 pm 05:09 PM

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

在Codecanyon上的12个最佳PHP聊天脚本 在Codecanyon上的12个最佳PHP聊天脚本 Mar 13, 2025 pm 12:08 PM

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

解释PHP中晚期静态结合的概念。 解释PHP中晚期静态结合的概念。 Mar 21, 2025 pm 01:33 PM

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

自定义/扩展框架:如何添加自定义功能。 自定义/扩展框架:如何添加自定义功能。 Mar 28, 2025 pm 05:12 PM

本文讨论了将自定义功能添加到框架上,专注于理解体系结构,识别扩展点以及集成和调试的最佳实践。

See all articles