时间:2021-07-01 10:21:17 帮助过:15人阅读
<?php class Father{ public function construct(){ echo '我是父类的构造方法!'; } protected function say($str = 'Hello World!'){ echo '说了一句话:' . $str; } } ?>
然后呢,搞一个子类去继承他:
<?php class chirld extends Father{ public construct(){ echo '我是子类的构造方法~'; } }
此时你实例化子类,结果将会是我是子类的构造方法~
!
当然,因为继承
关系,所以子类是可以调用父类的say()
方法的。
如果你想实现父类的构造方法,然而你又想实现子类的构造方法,你可以这样子去做:
<?php class chirld extends Father{ public construct(){ parent::construct(); echo '我是子类的构造方法~'; } } ?>
这时候就会输出我是父类的构造方法!
和我是子类的构造方法~
。
假设你在子类中定义了这么一个方法:
protected function say($str = ''){ echo '我是子类的say'; }
那么,你此时从父类继承下来的sys()
方法将会被重写,所以调用后输出的结果就是:我是子类的say
。
如果你这样定义会怎样?
public function say($str = ''){ echo '我是子类的方法哦~'; }
这样的写法还是可以的。PHP跟其他强类型语言不同的地方是,PHP重写方法允许你对重写的方法”向上公有化”,而不允许你”向下私有化”,就比如在这里你定义为private
是肯定会报错的,而像C++这样语言确恰恰相反。
PHP的对于这种情况的思想就是,你父亲给了你受保护级别的遗产,此时在你手上是保护级别的,你父亲允许你对对别人分享,也就是public
,但不允许你自己藏起来,也就是private
,自己独吞肯定不行的。
此时你肯定会问,那么父类的say()
设置为private
会怎样?
结果不会怎样,就是父类已经私有化了,子类根本继承不到,所以你在子类中的say()
方法随你这么定都可以。
还有一个问题,就是父类已经定义了sys()
中带可选参数,那么,在子类中的你像下面这样无参数定义会怎样呢?
public function say(){ echo '哈哈。我没有参数了耶~'; }
结果还是可以正常运行的,只不过会有 E_STRICT
级的提示。原因在于PHP标准就是参数的数量必须跟父类对齐,当然,可以在php.ini中进行错误级别设置。
以上就是php类的继承用法实例详解的详细内容,更多请关注Gxl网其它相关文章!