父类$this访问的函数

本文通过PHP代码展示了类继承与方法覆盖的基本概念,包括父类与子类之间的方法调用,以及如何在子类中重写父类方法。

测试类:

<?php
class pa{
    protected function m(){
        echo 'Parent\'s function';
    }
    public function run(){
        $this->m();
    }
}
class child extends pa{
    protected function m(){
        echo 'child\'s function';
    }
}
$obj=new child();
$obj->run();

//echo 'child\'s function';


<?php
class pa{
    private function m(){
        echo 'Parent\'s function';
    }
    public function run(){
        $this->m();
    }
}
class child extends pa{
    private function m(){
        echo 'child\'s function';
    }
}
$obj=new child();
$obj->run();

//echo 'Parent\'s function';


<?php
class pa{
    public function m(){
        echo 'Parent\'s function';
    }
    public function run(){
        $this->m();
    }
}
class child extends pa{
    public function m(){
        echo 'child\'s function';
    }
}
$obj=new child();
$obj->run();

//echo 'child\'s function';


### 父类与子类构造函数的执行顺序及关系 在面向对象编程中,父类和子类之间的构造函数调用顺序是一个重要的概念。以下是关于这一主题的具体分析: #### 构造函数调用顺序 当创建一个子类的对象时,其构造过程遵循一定的顺序。具体来说,这个顺序可以分为以下几个部分[^1][^2]: 1. **静态数据成员初始化**: 如果存在任何静态数据成员,则它们会在类加载阶段被初始化。 2. **父类构造函数调用**: 子类的构造函数会隐式或显式地调用父类的构造函数。如果未指定具体的父类构造函数调用,默认情况下会调用无参构造函数。 3. **非静态数据成员初始化**: 接着会对当前类中的非静态数据成员进行初始化。 4. **子类自己的构造函数执行**: 最后才执行子类自身的构造逻辑。 这种设计确保了继承链上的每一个层次都能完成必要的初始化工作,从而使得整个对象处于一致的状态。 #### 虚方法的行为 值得注意的是,在某些语言(如 C# 或 Java)中,即使是在父类的构造过程中也可能触发对子类定义的方法调用。这是因为此时已经决定了运行期类型为子类实例[^3]。然而需要注意的是,由于此时子类尚未完全构建好自己特有的状态,因此可能会引发不可预期的结果或者错误行为。 ```csharp // 示例代码展示父子类间构造器交互情况 public class BaseClass { public BaseClass() { Console.WriteLine("Base Class Constructor"); ShowMessage(); // 可能会调用到派生类版本的消息显示功能 } virtual protected void ShowMessage(){ Console.WriteLine("Base Message"); } } public class SubClass : BaseClass{ private string _message; public SubClass(string message){ this._message = message; Console.WriteLine("Subclass Field Initialized:" + _message); } override protected void ShowMessage(){ Console.WriteLine(_message ?? "Default Subclass Message"); } } ``` 上述例子展示了如何通过基类构造期间间接访问到了尚处半成品状态下的衍生实体内部属性状况风险所在之处。 #### 总结 综上所述,无论是哪种实现方式下,都强调了一个基本原则——即始终优先保障基础结构层面准备工作顺利完成之后再去处理更高级别的定制需求;同时也提醒开发者注意潜在陷阱特别是在涉及多态特性运用场景当中可能出现异常情形加以规避之策。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值