深入理解PHP面向对象之后期静态绑定

介绍

自 PHP 5.3.0 起,PHP 增加了一个叫做后期静态绑定的功能,用于在继承范围内引用静态调用的类。

准确说,后期静态绑定工作原理是存储了在上一个“非转发调用”(non-forwarding call)的类名。当进行静态方法调用时,该类名即为明确指定的那个(通常在 :: 运算符左侧部分);当进行非静态方法调用时,即为该对象所属的类。所谓的“转发调用”(forwarding call)指的是通过以下几种方式进行的静态调用:self::parent::static:: 以及 forward_static_call()。可用 get_called_class() 函数来得到被调用的方法所在的类名,static:: 则指出了其范围。

转发调用&非转发调用

转发调用

所谓的转发调用是指:在类的方法调用中转发调用信息(可以理解为调用栈信息)

  • 转发调用的时机

    • parent调用

    • self调用

    • static调用

    • forward_static_call()

      非转发调用

      所谓的非转发调用是指:是明确的指定静态调用的类名或通过对象(伪对象)实例的调用

      代码解析

      <?php
      class A
      {
      public static function foo()
      {
        static::who();
      }
      
      public static function who()
      {
        echo __CLASS__ . "\n";
      }
      }
      class B extends A
      {
      public static function test()
      {
        //非转发调用
        A::foo();
        //转发调用
        parent::foo();
        //转发调用
        self::foo();
      }
      
      public static function who()
      {
        echo __CLASS__ . "\n";
      }
      }
      class C extends B
      {
      public static function who()
      {
        echo __CLASS__ . "\n";
      }
      }
      //非转发调用
      C::test();

      后期静态绑定

      该功能从语言内部角度考虑被命名为“后期静态绑定”。“后期绑定”的意思是说,static:: 不再被解析为定义当前方法所在的类,而是在实际运行时计算的。也可以称之为“静态绑定”,因为它可以用于(但不限于)静态方法的调用。

      后期静态绑定实现原理

      后期静态绑定工作原理是存储了在上一个“非转发调用”(non-forwarding call)的类名。
      这句话的意思就是在程序运行过程中到底如何确认static是哪个类,确定规则是取上次存储的非转发调用的类

      后期静态绑定应用

  • 单例继承场景

  • 抽象类和实现类

本作品采用《CC 协议》,转载必须注明作者和本文链接
讨论数量: 1

再编辑一下吧 有点乱

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!