详解PHP中abstract(抽象)、final(终究)和static(静态)道理与用途
本文实例讲述了PHP中abstract(抽象)、final(终究)和static(静态)道理与用途。分享给大家供大家参照 ,详细如下:
abstract(抽象)
PHP 5 支撑抽象类和抽象办法。定义为抽象的类不克不及被实例化。任何一个类,假如它里面至少有一个办法是被声明为抽象的,那么这个类就必需被声明为抽象的。被定义为抽象的办法只是声明了其调取方式(参数),不克不及定义其详细的功效实现。
继承一个抽象类的时候,子类必需定寄父类中的所有抽象办法;别的,这些办法的拜访操纵必需和父类中一样(或者更为宽松)。例如某个抽象办法被声明为受庇护的,那么子类中实现的办法就应当声明为受庇护的或者公有的(严厉程度:private>protected>public),而不克不及定义为私有的。此外办法的调取方式必需匹配,即类型和所需参数数目必需一致。例如,子类定义了一个可选参数,而父类抽象办法的声明里没有,则两者的声明并无冲突。 这也适用于 PHP 5.4 起的结构函数。在 PHP 5.4 此前的结构函数声明可以不一样的。
相关学习引荐:PHP编程从入门到熟知
总结:
抽象类不克不及被实例化;
类中有任何抽象办法那这个类也必需为抽象的;
抽象类只能说明调取方式和参数,不克不及定义详细功效实现;
继承抽象类的子类必需实现抽象类的所有抽象办法;
子类中实现的抽象办法的拜访操纵必需比父类的拜访操纵更严厉;
子类中实现的办法的调取方式及参数数目必需与被实现的办法一致。
例:
<?php abstract class AbstractClass { // 强迫要求子类定义这些办法,不定义功效实现 abstract protected function getValue(); abstract protected function prefixValue($prefix); // 一般办法(非抽象办法),子类可以不重写 public function printOut() { print $this->getValue() . "\n"; } } class ConcreteClass1 extends AbstractClass { protected function getValue() { 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"; ?>
<?php abstract class AbstractClass { // 我们的抽象办法仅需要定义需要的参数 abstract protected function prefixName($name); } class ConcreteClass extends AbstractClass { // 我们的子类可以定寄父类签名中不存在的 可选参数 public function prefixName($name, $separator = ".") { if ($name == "Pacman") { $prefix = "Mr"; } elseif ($name == "Pacwoman") { $prefix = "Mrs"; } else { $prefix = ""; } return "{$prefix}{$separator} {$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 起,可以用一个变量来动态调取类。但该变量的值不克不及为关键字 self,parent 或 static。
总结:
静态办法无需实例化,可直接拜访;
类实例化的对象没法拜访类中的静态属性,但是可以拜访静态办法;
伪变量
$this
在静态办法中不成用;静态属性不成以由对象通过 -> 操纵符来拜访;
用静态方式调取一个非静态办法会致使一个
E_STRICT
级别的错误;静态属性只能被初始化为文字或常量,不克不及使用表达式(函数返回值/宁一个变量/对象);
可以用一个变量来动态调取类。但该变量的值不克不及为关键字 self,parent 或 static。
<?php class Foo { public static $my_static = 'foo'; public function staticValue() { return self::$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.0 print Bar::$my_static . "\n"; $bar = new Bar(); print $bar->fooStatic() . "\n"; ?> </programlisting> </example> <example> <title>静态办法示例</title> <programlisting role="php"> <![CDATA[ <?php class Foo { public static function aStaticMethod() { // ... } } Foo::aStaticMethod(); $classname = 'Foo'; $classname::aStaticMethod(); // 自 PHP 5.3.0 起 ?>
以上就是详解PHP中abstract(抽象)、final(终究)和static(静态)道理与用途的具体内容,更多请关注百分百源码网其它相关文章!