php Trait基类use trait,本类不use

yizhihongxing

一 回顾trait使用

https://blog.csdn.net/bushuwei/article/details/103514174
发现之前本人说明很模糊,自己居然不知道为什么
其实这里的$c,就是class B
再次回顾逻辑

二 分析

  • self和static区别说的没毛病
  • Trait基类use trait,本类不use。那么如果用的new self,则你new 出来的就是 use trait者。如果new static,则因为有继承关系, 它会判断类是否存在(父子会被认为都是同一个static,则不再new),那么,谁先调用instance,那么new出来的就是谁。‘Trait基类use trait,本类不use’->直接‘其实这里的$c,就是class B’是错的。之所以有这个‘幻觉’,是因为单例模式,且static

三 上代码

  1. self+单例
    trait A{
        private static $instance;
        static function getInstance()
        {
            if(!isset(self::$instance)){
                self::$instance = new self();
            }
            return self::$instance;
        }
    }
    
    class B{
        use A;
        function a()
        {
            var_dump('call at B');
        }
    }
     
    class C extends B{
        function a()
        {
            var_dump('call at c');
            parent::a();
        }
    }
     
    class D extends B{
        use A;
        function a()
        {
            var_dump('call at D');
            parent::a(); 
        }
    }
    $b = B::getInstance();
    $c = C::getInstance();
    $d = D::getInstance();
     
    $c->a();
    echo "<br/>";
    $d->a();
    echo "<br/>";
    

      

    string(9) "call at B"
    string(9) "call at D" string(9) "call at B" 

    注视掉

    // $b = B::getInstance();
    结果不变
  2. static+单例
    trait A{
        private static $instance;
        static function getInstance()
        {
            if(!isset(self::$instance)){
                self::$instance = new static();
            }
            return self::$instance;
        }
    }
    
    class B{
        use A;
        function a()
        {
            var_dump('call at B');
        }
    }
     
    class C extends B{
        function a()
        {
            var_dump('call at c');
            parent::a();
        }
    }
     
    class D extends B{
        use A;
        function a()
        {
            var_dump('call at D');
            parent::a(); 
        }
    }
    $b = B::getInstance();
    $c = C::getInstance();
    $d = D::getInstance();
     
    $c->a();
    echo "<br/>";
    $d->a();
    echo "<br/>";
    
    string(9) "call at B"
    string(9) "call at D" string(9) "call at B" 
    

     

    注视掉

    // $b = B::getInstance();
    string(9) "call at c" string(9) "call at B"
    string(9) "call at D" string(9) "call at B" 

     

  3. 
    

     self+非单例

      

    trait A{
        private static $instance;
        static function getInstance()
        {
            self::$instance = new self();
            return self::$instance;
        }
    }
    
    class B{
        use A;
        function a()
        {
            var_dump('call at B');
        }
    }
     
    class C extends B{
        function a()
        {
            var_dump('call at c');
            parent::a();
        }
    }
     
    class D extends B{
        use A;
        function a()
        {
            var_dump('call at D');
            parent::a(); 
        }
    }
    $b = B::getInstance();
    $c = C::getInstance();
    $d = D::getInstance();
     
    $c->a();
    echo "<br/>";
    $d->a();
    echo "<br/>";
    

      

    string(9) "call at B"
    string(9) "call at D" string(9) "call at B" 
    

      注释掉

    // $b = B::getInstance();

    结果不变

  4.  static+非单例
    trait A{
        private static $instance;
        static function getInstance()
        {
            // if(!isset(self::$instance)){
            //     self::$instance = new static();
            // }
            // return self::$instance;
            self::$instance = new static();
            return self::$instance;
        }
    }
    
    class B{
        use A;
        function a()
        {
            var_dump('call at B');
        }
    }
     
    class C extends B{
        function a()
        {
            var_dump('call at c');
            parent::a();
        }
    }
     
    class D extends B{
        use A;
        function a()
        {
            var_dump('call at D');
            parent::a(); 
        }
    }
    $b = B::getInstance();
    $c = C::getInstance();
    $d = D::getInstance();
     
    $c->a();
    echo "<br/>";
    $d->a();
    echo "<br/>";
    

      

    string(9) "call at c" string(9) "call at B"
    string(9) "call at D" string(9) "call at B" 
    

      注释掉
    $b = B::getInstance();
    结果不变

四 结论

  • self的话,就是谁use的,就是谁
  • static的话,谁调用的就是谁
  • 但是static会出现‘谁use就是谁’的幻觉,那是因为单例模式,前面创建了相同类型的单例。

原文链接:https://www.cnblogs.com/bushuwei/p/17277267.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:php Trait基类use trait,本类不use - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • MySQL如何快速导入数据

    MySQL是一种常用的关系型数据库管理系统,对于需要导入大量数据的情况,如何高效地完成数据导入就显得尤为重要。以下是MySQL如何快速导入数据的完整攻略。 1. 准备工作 在开始导入数据之前,需要先进行一些准备工作,包括: 确保已经创建好了要导入数据的表,表结构要与数据文件中的字段类型、数量等相同。 (可选)将要导入的数据文件转换为MySQL支持的格式,如C…

    PHP 2023年5月27日
    00
  • php删除数组中重复元素的方法

    当我们使用 PHP 数组时,经常需要删除其中的重复元素。下面是一些常用的方法: 方法一:使用 array_unique 函数 $array = array("a", "b", "a", "c"); $array = array_unique($array); print_r($a…

    PHP 2023年5月26日
    00
  • PHP文件上传功能实现逻辑分析

    以下是“PHP文件上传功能实现逻辑分析”的完整使用攻略,包括实现逻辑、代码示例和注意事项等内容。 实现逻辑 PHP文件上传功能的实现逻辑如下: 在HTML表单中添加文件上传控件,例如: “`html “` 在上述表单中,action属性指定表单提交的URL地址,method属性指定表单提交的HTTP方法,enctype属性指定表单提交的编码类型,inpu…

    PHP 2023年5月12日
    00
  • php实现数组筛选奇数和偶数示例

    下面是关于PHP实现数组筛选奇数和偶数的完整攻略。 1. 筛选奇数和偶数的逻辑 在进行本题的筛选操作之前,我们需要了解一下筛选奇数和偶数的具体逻辑。 奇数:除以 2 的余数为 1。 偶数:除以 2 的余数为 0。 因此,在 PHP 中,我们可以使用取模操作,即 % 符号,来进行筛选操作。 2. 示例1:使用 for 循环实现筛选 首先,我们可以使用 for …

    PHP 2023年5月26日
    00
  • PHP文字转图片功能原理与实现方法分析

    PHP文字转图片功能原理与实现方法分析 原理分析 实现 PHP 文字转图片的原理主要分为两个步骤:文字的绘制和图片的保存。文字的绘制可以使用 PHP 中的 GD 库来实现,GD 库由一系列绘图函数组成,能够支持各种图像操作,比如绘制线条、椭圆、多边形和文本等。图片的保存则可以使用 PHP 中的 imagepng() 函数来实现,该函数主要用于将图像输出到浏览…

    PHP 2023年5月26日
    00
  • 微信小程序实现图片放大预览功能

    下面是“微信小程序实现图片放大预览功能”的完整攻略: 1. 使用自带组件<image>展示图片 我们可以使用小程序自带的<image>组件来展示图片,示例代码如下: <image src="{{imageUrl}}"></image> 其中imageUrl为图片的网络链接或本地临时文件路径。…

    PHP 2023年5月23日
    00
  • php设计模式 Prototype (原型模式)代码

    下面介绍一下”php设计模式 Prototype (原型模式)代码”的完整攻略。 什么是Prototype模式 Prototype模式是一种创建型模式,其核心在于通过复制现有的对象实例来创建新的实例,而不是通过使用构造函数或工厂方法直接创建,并且不需要知道创建的细节。 Prototype模式的优点 通过复制现有的实例来创建新的实例,可以简化对象的创建过程,降…

    PHP 2023年5月23日
    00
  • php str_getcsv把字符串解析为数组的实现方法

    PHP str_getcsv把字符串解析为数组的实现方法 在开发过程中,经常需要处理csv格式的数据,而php中可以通过str_getcsv函数来将csv格式的字符串解析成数组,本文将详细介绍str_getcsv函数的实现方法。 函数定义与参数 str_getcsv函数用于将csv格式的字符串转化为数组,其定义如下: array str_getcsv ( s…

    PHP 2023年5月26日
    00
合作推广
合作推广
分享本页
返回顶部