首页 > 作文

PHP中abstract(抽象)、final(最终)和static(静态)原理与用法详解

更新时间:2023-04-08 17:41:44 阅读: 评论:0

本文实例讲述了php中abstract(抽象)、final(最终)和static(静态)原理与用法。分享给大家供大家参考,具体如下:

abstract(抽象)

php 5 支持抽象类和抽象方法。定义为抽象的类不能被实例化。任何一个类,如果它里面至少有一个方法是被声明为抽象的,那么这个类就必须被声明为抽象的。被定义为抽象的方法只是声明了其调用方式(参数),不能定义其具体的功能实现

继承一个抽象类的时候,子类必须定义父类中的所有抽象方法;另外,这些方法的访问控制必须和父类中一样(或者更为宽松)。例如某个抽象方法被声明为受保护的,那么子类中实现的方法就应该声明为受保护的或者公有的(严格程度:private>protected>public),而不能定义为私有的。此外方法的调用方式必须匹配,即类型和所需参数数量必须一致。例如,子类定义了一个可选参数,而父类抽象方法的声明里没有,则两者的声明并无冲突。 这也适用于 php 5.4 起的构造函数。在 php 5.4 之前的构造函数声明可以不一样的。

总结:

抽象类不能被实例化;类中有任何抽象方法那这个类也必须为抽象的;抽象类只能申明调用方式和参数,不能定义具体功能实现;继承抽象类的子类必须实现抽象类的所有抽象方法;子类中实现的抽象方法的访问控制必须比父类的访问控制更严格;子类中实现的方法的调用方式及参数数量必须与被实现的方法一致。

例:

<?phpabstract class abstractcl打鸡血ass{  // 强制要求子类定义这些方法,不定义功能实现  abstract protected function getvalue();  abstract protected function prefixvalue($prefix);  // 普通方法(非抽象方法),子类可以不重写  public function printout() {    print $this->getvalue() . "\n";  }}class concreteclass1 extends abstractclass{  protected function g关于元旦的对联etvalue() {    return "concreteclass1";  }  public function prefixvalue($prefix) {    return "{$prefix}concreteclass1";  }}class concreteclass2 extends abstractclass{ //访问方式可以更宽松  public function getvalue() {    return "concreteclass2";  }  public function prefixvalue($prefix) {    return "{$prefix}concreteclass2";  }}$class1 = new concreteclass1;$class1->printout();echo $class1->prefixvalue('foo_') ."\n";$class2 = new concreteclass2;$class2->printout();echo $class2->prefixvalue('foo_') ."\n";?>
<?phpabstract class abstractclass{  // 我们的抽象方法仅需要定义需要的参数  abstract protected function prefixname($name);}class concreteclass extends abstractclass{  // 我们的子类可以定义父类签名中不存在的 可选参数  public function prefixname($name, $parator = ".") {    if ($name == "pacman") {      $prefix = "mr";    } elif ($name == "pacwoman") {      $prefix = "mrs";    } el {      $prefix = "";    }    return "{$prefix}{$parator} {$name}";  }}$class = new concreteclass;echo $class->prefixname("pacman"), "\n";echo $class->prefixname("pacwoman"), "\n";?>

final

如果父类中的方法被声明为 final,则子类无法覆盖该方法。如果一个类被声明为 final,则不能被继承。

这个比较好理解,不做赘述

static

声明类属性或方法为静态,就可以不实例化类而直接访问。静态属性不能通过一个类已实例化的对象来访问(但静态方法可以)。

为了兼容 php 4,如果没有指定访问控制,属性和方法默认为公有。

由于静态方法不需要通过对象即可调用,所以伪变量 $this 在静态方法中不可用。

静态属性不可以由对象通过 -> 操作符来访问。

用静态方式调用一个非静态方法会导致一个 e_strict 级别的错误。

就像其它所有的 php 静态变量一样,静态属性只能被初始化为文字或常量,不能使用表达式。所以可以把静态属性初始化为整数或数组,但不能初始化为另一个变量或函数返回值,也不能指向一个对象。

自 php 5.3.0 起,可以用一个变量来动态调用类。但该变量的值不能为关键字 lf,parent 或 static。

总结:

静态方法无需实例化,可直接访问;类实例化的对象无法访问类中的静态属性,但是可以访想女朋友的情话问静态方法;伪变量 $this 在静态方法中不可用;静态属性不可以由对象通过 -> 操作符来访问;用静态方式调用一个非静态方法会导致一个 e情侣昵称大全_strict 级别的错误;静态属性只能被初始化为文字或常量,不能使用表达式(函数返回值/宁一个变量/对象);可以用一个变量来动态调用类。但该变量的值不能为关键字 lf,parent 或 static。
<?phpclass foo{  public static $my_static = 'foo';  public function staticvalue() {    return lf::$my_static;  }}class bar extends foo{  public function foostatic() {    return parent::$my_static;  }}print foo::$my_static . "\n";$foo = new foo();print $foo->staticvalue() . "\n";print $foo->my_static . "\n";   // undefined "property" my_static print $foo::$my_static . "\n";$classname = 'foo';print $classname::$my_static . "\n"; // as of php 5.3.0print bar::$my_static . "\n";$bar = new bar();print $bar->foostatic() . "\n";?&国家语言gt;  </programlisting> </example> <example>  <title>静态方法示例</title>  <programlisting role="php"><![cdata[<?phpclass foo {  public static function astaticmethod() {    // ...  }}foo::astaticmethod();$classname = 'foo';$classname::astaticmethod(); // 自 php 5.3.0 起?>

本文发布于:2023-04-08 17:41:42,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/e4798d84d48877e59325dc93a327cfbc.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP中abstract(抽象)、final(最终)和static(静态)原理与用法详解.doc

本文 PDF 下载地址:PHP中abstract(抽象)、final(最终)和static(静态)原理与用法详解.pdf

标签:方法   静态   抽象   子类
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图