zoukankan      html  css  js  c++  java
  • php重载

    <?php
    /*
    * php面向对象的重写与重载
    重写:
    就是当子类继承父类的一些方法后,子类又在其内部定义了相同的方法,则这个新定义的方法会覆盖继承而来的父类的方法,子类只能调用其内部定义的方法。

    有以下几点要求:

    1.当一个父类和子类有一个方法,参数和名字完全一致,那么子类方法会覆盖父类的方法。

    必须参数一致,才会实现方法覆盖。当参数个数不一致,则会报错(这就牵扯到上面说所得方法重载)。当方法名字不一致,就不会覆盖,只是子类新定义的方法。

    2.在实行方法覆盖的时候,访问修饰符可以是不一样的,但是子类的访问范围必须大于等于父类的访问范围。

    这是php这些语言设计时的规定吧。我是这么理解的是访问高一层的东西比较容易,如果再去访问底层的东西权限肯定要高一些。

    要求参数和名字一样。并不是要求子类,父类名称相同。

    是要求参数和名字一样,具体就是要求参数的个数与父类相同,而并不是参数名称一致。即传递的参数名字可以为任意,只要保证传递的个数相同即可。

    看代码:
    */

    class shao
    {
    public function sasa($name){
    echo $name,'狗!<br/>';
    }
    }
    class zhen extends shao{
    public function aaa()
    {
    echo '猫<br/>';
    }
    }
    $lli = new zhen();
    $lli->aaa();
    $lli->aaa('binghh');
    ?>


    <?php
    class fu
    {
    public function text(){
    echo '父类';
    }
    public function textt(){
    echo '父亲';
    }
    }
    class erzi extends fu{
    public function text()
    {
    parent::text();//我要父类的东西
    echo '儿子';//重写

    }
    }
    $shili = new fu();
    $erzi = new erzi();
    $erzi->text();
    ?>
    <?php
    /**
    重载:
    重载是类的多态的一种实现。函数重载指一个标识符被用作多个函数名,且能够通过函数的参数个数或参数类型将这些同名的函数区分开来,调用不发生混淆。即当调用的时候,虽然方法名字相同,但根据参数的不同可以自动调用相应的函数。
    php不好实现。
    可以使类里面的某个方法产生多种效果,根据传入参数不同,可以执行不同的逻辑。
    有以下几点要求:

    1、在使用重载时只能通过相同的方法名、不同的参数形式实现。不同的参数类型可以是不同的参数类型,不同的参数个数,不同的参数顺序(参数类型必须不一样);
    2、不能通过访问权限、返回类型、抛出的异常进行重载;
    3、方法的异常类型和数目不会对重载造成影响;
    有点复杂 代码不准...
    */
    class fu
    {
    public function text(){
    echo '父类';
    }
    public function textt(){
    echo '父亲';
    }
    }
    class erzi extends fu
    {
    function test($name)
    {
    //方法重载
    parent::text();//我要父类的东西
    echo "erzi",$name;//重写

    }
    }

    $erzi = new fu();
    $erzi-> text("123");

    //复制代码
    //重写只存在于子类与父类中,重载存在于一个类中。
    //
    //override是重写
    //
    //overload是重载
    ?>
  • 相关阅读:
    ArcGIS Pro 简明教程(2)基础操作和简单制图
    ArcGIS Pro 简明教程(1)Pro简介
    ArcGIS Pro 简明教程(3)数据编辑
    LocaSpaceViewer深度讲解(一)瓦片服务与数据下载
    迭代最近点算法 Iterative Closest Points
    应用Fast ICP进行点集或曲面配准 算法解析
    八叉树-OcTree
    2016年10月校招体会
    静态代码块&非静态代码块&构造函数
    avtivity与view
  • 原文地址:https://www.cnblogs.com/ZJCD/p/7338052.html
Copyright © 2011-2022 走看看