<?php
class A {
const CONST_NAME = 'A';
public static $static_name = 'A';
public static $static_name_no_rewrite = 'A'; private static $_instance; public static function static_func() {
echo 'A';
} public static function static_func_no_rewrite() {
echo 'A';
} public static function static_extends_self() {
echo self::$static_name;
} public static function static_extends_no_rewrite_self() {
echo self::$static_name;
} public static function static_extends_no_vars() {
return self::$static_no_vars;
} public static function get_instance() {
if (empty(self::$_instance)) {
self::$_instance = new self();
}
return self::$_instance;
}
} class B extends A {
const CONST_NAME = 'B';
public static $static_name = 'B';
public static $static_no_vars = 'B'; //重写
public static function static_func() {
echo 'B';
} public static function static_extends_self() {
echo self::$static_name;
}
}
//是否继承后是有了一个父类的引用 //1.查看父类和子类的初始情况
$str = '1.查看父类和子类的初始情况';
echo '<hr />';
echo $str, '<br />';
echo 'A::CONST_NAME->', A::CONST_NAME, '<br />';
echo 'B::CONST_NAME->', B::CONST_NAME, '<br />';
echo 'A::$static_name->', A::$static_name, '<br />';
echo 'B::$static_name->', B::$static_name, '<br />';
echo 'B::$static_name_no_rewrite->', B::$static_name_no_rewrite, '<br />';
echo 'B::$static_name_no_rewrite->', B::$static_name_no_rewrite, '<br />';
echo '结论:静态属性或类常量可以被继承<br />';
echo '<hr />'; //2.测试重定义的类属性 修改子类(父类)的值父类(子类)的值是否会改变
$str = '2.测试重定义的类属性 修改子类(父类)的值父类(子类)的值是否会改变';
echo $str, '<br />';
A::$static_name = 'M_A';
echo "修改->A::\$static_name = 'M_A'<br />";
echo 'A::$static_name->', A::$static_name, '<br />';
echo 'B::$static_name->', B::$static_name, '<br />';
B::$static_name = 'M_B';
echo "修改->B::\$static_name = 'M_B'<br />";
echo 'A::$static_name->', A::$static_name, '<br />';
echo 'B::$static_name->', B::$static_name, '<br />';
echo '结论:继承关系的两个类,如果子类重定义了父类的静态属性,则修改父类(子类)的静态属性或常量不会影响到子类(父类)的对应静态属性<br />';
echo '<hr />'; //3.测试没有重定义的类属性 修改子类(父类)的值父类(子类)的值是否会改变
$str = '3.测试没有重定义的类属性 修改子类(父类)的值父类(子类)的值是否会改变';
echo $str, '<br />';
echo 'A::$static_name_no_rewrite->', A::$static_name_no_rewrite, '<br />';
echo 'B::$static_name_no_rewrite->', B::$static_name_no_rewrite, '<br />';
A::$static_name_no_rewrite = 'M_A';
echo "修改->A::\$static_name_no_rewrite = 'M_A'<br />";
echo 'A::$static_name_no_rewrite->', A::$static_name_no_rewrite, '<br />';
echo 'B::$static_name_no_rewrite->', B::$static_name_no_rewrite, '<br />';
B::$static_name_no_rewrite = 'M_B';
echo "修改->B::\$static_name_no_rewrite = 'M_B'<br />";
echo 'A::$static_name_no_rewrite->', A::$static_name_no_rewrite, '<br />';
echo 'B::$static_name_no_rewrite->', B::$static_name_no_rewrite, '<br />';
echo '结论:如果子类没有重定义父类的某个静态属性,则修改父类(子类)则子类(父类)的对应静态属性也随之改变<br />';
echo '更深结论:子类继承父类会有一个父类的引用指向父类那块内存,如果子类没有重定义一个属性(放到本类内存下)就会调用父类的属性<br />';
echo '<hr />'; //4.静态方法是否能继承
$str = '4.静态方法是否能继承';
echo $str, '<br />';
echo 'A::static_func_no_rewrite()->', A::static_func_no_rewrite(), '<br />';
echo 'B::static_func_no_rewrite()->', B::static_func_no_rewrite(), '<br />';
echo '结论:静态方法可以继承!';
echo '<hr />'; //5.静态方法是否能被重写
$str = '5.静态方法是否能被重写';
echo $str, '<br />';
echo 'A::static_func()->', A::static_func(), '<br />';
echo 'B::static_func()->', B::static_func(), '<br />';
echo '结论:静态方法可以被重写!';
echo '<hr />'; //6.父类静态方法中有self, 子类继承此方法没有重写后调用的self是谁?
$str = '6.父类静态方法中有self, 子类继承此方法没有重写后调用的self是谁?';
echo $str, '<br />';
echo 'A::static_extends_no_rewrite_self()->', A::static_extends_no_rewrite_self(), '<br />';
echo 'B::static_extends_no_rewrite_self()->', B::static_extends_no_rewrite_self(), '<br />';
echo '结论:与3相同, 如若没有重写, 则只是子类对父类的一个引用, 如果子类中没有, 就去父类中寻找, 而且找到的也是依赖于父类!';
echo '更深结论:在PHP单例的继承中, 父类::get_instance()方法中返回new self(), 如果子类没有重写, 则返回父类的实例!';
echo '<hr />'; //7.父类静态方法中有self, 子类继承此方法重写后调用的self是谁?
$str = '7.父类静态方法中有self, 子类继承此方法重写后调用的self是谁?';
echo $str, '<br />';
echo 'A::static_extends_self()->', A::static_extends_self(), '<br />';
echo 'B::static_extends_self()->', B::static_extends_self(), '<br />';
echo '结论:子类覆盖父类的方法后, 如果其中有self属性, 则此时会覆盖父类的self, 即此时的self为对象本身';
echo '<hr />'; //8.父类静态方法调用本身没有子类却有的静态属性(来验证上述6推测, 如果是引用, 则会为空)
$str = '8.子类调用父类静态方法调用父类没有子类却有的self的静态属性(来验证上述6推测, 如果是引用, 则会为空)';
echo $str, '<br />';
//echo 'B::static_extends_no_vars()->', B::static_extends_no_vars(), '<br />';
echo 'B::static_extends_no_vars()->报错<br />';
echo '结论:程序报错, 显示A没有此属性, 说明是子类对父类的一个引用!子类如果没有重写父类的属性或静态方法, 则调用父类的!包括self!';
echo '<hr />'; //9.测试下6中的推断, 即单例模式中self
$str = '9.测试下6中的推断, 即单例模式中self';
echo $str, '<br />';
echo 'get_class(B::get_instance())->', get_class(B::get_instance()), '<br />';
echo '结论:说明6中的更深推断是正确的!';
echo '<hr />'; //10.测试实例调用静态属性或常量
$str = '测试实例调用静态属性或常量';
echo $str, '<br />';
$a = new A();
//echo '$a = new A();echo $a->CONST_NAME->', $a->CONST_NAME, '<br />';
echo '$a = new A();echo $a->CONST_NAME->报错<br />';
//echo 'echo $a->$static_name->', $a->$static_name, '<br />';
echo 'echo $a->$static_name->报错<br />';
echo '结论:实例不能调用类的静态属性或常量!调用静态属性会转变为变量的变量, 调用常量会调用实例的对应属性!';
echo '<hr />'; //11.测试实例调用静态方法
$str = '测试实例调用静态属性或常量';
echo $str, '<br />';
echo '$a->static_func()->', $a->static_func(), '<br />';
echo '$a->static_extends_self()->', $a->static_extends_self(), '<br />';
echo '结论:实例可以调用静态方法, 甚至静态方法中包含self!';
echo '<hr />';

PHP-静态方法(static)继承等分析的更多相关文章

  1. 第32节:Java中-构造函数,静态方法,继承,封装,多态,包

    构造函数实例 class Cat{ // 设置私有的属性 name private String name; // 设置name的方法 public void setName(String Name) ...

  2. .net类中静态方法的继承

    父类中的静态方法,继承的子类能不能调用?一直在这里有疑惑,即使在下面的测试之后,也只是得到了结论,不明原理. class ClsParent { public static void ShowSth( ...

  3. static 继承

    静态方法大家应该都比较熟悉,在这里主要谈一下静态方法在继承时的一些注意事项. 1.父类方法如果是静态方法,子类不能覆盖为非静态方法: 2.父类方法如果是非静态方法,子类不能覆盖为静态方法: 3.父类静 ...

  4. koa 基础(十八)es6中的类、静态方法、继承

    1.app.js /** * es6中的类.静态方法.继承 */ // 定义Person类 class Person { constructor(name, age) { /*类的构造函数,实例化的时 ...

  5. 关于static继承的问题

    c++primer 15.2.7节关于static继承的意思是,父类和子类共享static函数或者static成员变量,并且子类要访问还要受它们的权限限制,下面是看到的另一个例子 class Base ...

  6. java中静态变量与静态方法的继承(转)

    总结: 1.静态变量与静态方法说继承并不确切,静态方法与变量是属于类的方法与变量.而子类也属于超类,比如说Manage extends Employee,则Manage也是一个Employee,所以子 ...

  7. Python中的单继承与多继承实例分析

    Python中的单继承与多继承实例分析 本文实例讲述了Python中的单继承与多继承.分享给大家供大家参考,具体如下: 单继承 一.介绍 Python 同样支持类的继承,如果一种语言不支持继承,类就没 ...

  8. koa 基础(十七)原生 JS 中的类、静态方法、继承

    1.app.js /** * 原生 JS 中的类.静态方法.继承 * es5中的类和静态方法 */ function Person(name, age) { // 构造函数里面的方法和属性 this. ...

  9. java中静态属性和和静态方法的继承问题 以及多态的实质

    首先结论是:java中静态属性和和静态方法可以被继承,但是没有被重写(overwrite)而是被隐藏. 静态方法和属性是属于类的,调用的时候直接通过类名.方法名完成的,不需继承机制就可以调用如果子类里 ...

随机推荐

  1. IndiaHacks 2016 - Online Edition (Div. 1 + Div. 2) E. Bear and Forgotten Tree 2 bfs set 反图的生成树

    E. Bear and Forgotten Tree 2 题目连接: http://www.codeforces.com/contest/653/problem/E Description A tre ...

  2. 简单破解 Sencha Architect 2.2 (ExtJs Designer)

    Sencha Architect 2是ExtJS和Sencha Touch的官方可视化IDE工具.最新版本是2.2,说是破解,其实是修改License来实现无限试用而已. 1.先下载安装官方软件,大约 ...

  3. Linux可以明文传输密码的工具sshpass

    普通ssh只能手动输入密码,但是sshpass可以明文指定密码,但不建议使用,太不安全了.

  4. The method setClass(Context, Class<?>) in the type Intent is not applicable for the arguments (GameV

    在当前短信内容的activity中写            Bundle bun = new Bundle();         bun.putString("message",  ...

  5. malloc和calloc的差别

    做C这么久了,才了解calloc函数也是挺丢人的. 从网上找了非常多关于这两者差别的文章.有的甚至总结了好多人的结论.但我感觉都没有说的非常明确. 当中关于函数原型的差别根本就不是必需再讨论了,是个人 ...

  6. 三款工作流引擎比较:WWF、netBPM 和 ccflow

    下面将对目前比较主流的三款工作流进行介绍和比较,然后通过三款流程引擎分别设计一个较典型的流程来给大家分别演示这三款创建流程的过程.这三款工作流程引擎分别是 Windows Workflow Found ...

  7. (转)H264通过RTMP发布 V2.0 (Red5 Wowza 测试通过)

    直接上代码 // demo.cpp : 定义控制台应用程序的入口点.//#include "stdafx.h"#includeextern "C"{#inclu ...

  8. windows10使用arcgis注意事项

    平板电脑模式

  9. hdu1269迷宫城堡 (强连通Tarjan+邻接表)

    Problem Description 为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000),每一个通道都是单向的,就是说 ...

  10. Django文档学习

    文档位置:https://docs.djangoproject.com/zh-hans/2.1/