在 PHP 里,在没有继承时候,你用self::class 和 static::class是同样的,都是获取当前类名。php
可是若是用到了继承,而且这个方法写在了父类里,你想要分别获取当前父类名和未知的子类名,就要按照下面的方法进行获取。测试
在 PHP 类中,self指向的是当前方法存在的这个类,也就是父类。static指向的是最终那个子类。code
class P { public static function getParent() { return self::class; } public static function getChild() { return static::class; } } class C extends P { } echo C::getParent(), PHP_EOL; echo C::getChild(), PHP_EOL;
运行结果:继承
P C
你觉得这样就结束了?不不不……get
今天心血来潮,写到一个功能,可能会用到trait的static,写了代码测试了下……代码就不贴了,没错,不管是self仍是static,都没法获取当前trait名。it
可是这不是重点,重点是下面的。我想要在trait中操做static属性,因为不清楚到底会指向谁,因此写了代码进行测试。io
trait T { public static $data1 = []; public static $data2 = []; public static $data3 = []; public function setData($name, $value) { static::$data1[$name] = $value; self::$data2[$name] = $value; T::$data3[$name] = $value; } } class A { use T; } class B extends A { } $a = new A; $b = new B; $a->setData('a', 1); $b->setData('b', 2); echo '[static]', PHP_EOL; var_dump(T::$data1, A::$data1, B::$data1); echo PHP_EOL, '[self]', PHP_EOL; var_dump(T::$data2, A::$data2, B::$data2); echo PHP_EOL, '[T]', PHP_EOL; var_dump(T::$data3, A::$data3, B::$data3);
运行结果:function
[static] array(0) { } array(2) { ["a"]=> int(1) ["b"]=> int(2) } array(2) { ["a"]=> int(1) ["b"]=> int(2) } [self] array(0) { } array(2) { ["a"]=> int(1) ["b"]=> int(2) } array(2) { ["a"]=> int(1) ["b"]=> int(2) } [T] array(2) { ["a"]=> int(1) ["b"]=> int(2) } array(0) { } array(0) { }
在trait中操做static属性,不管是self仍是static,指向的都是那个类的static属性。而只有直接使用trait名::静态属性
,能够指向到当前trait中存储静态属性。class