Защищенные статические переменные-члены

Недавно я работал над некоторыми файлами классов и заметил, что переменные-члены были установлены в защищенном статическом режиме, таком как защищенный статический $_someVar, и доступ к нему осуществляется как статический::$_someVar.

Я понимаю концепцию видимости и то, что если что-то установить в качестве защищенного статического, обеспечит доступ к переменной-члену только в суперклассе или производных классах, но могу ли я получить доступ к защищенным статическим переменным только в статических методах?

Спасибо

2 ответа

Решение

Если я правильно понимаю, то, что вы имеете в виду, называется поздне-статическими привязками. Если у вас есть это:

class A {
   static protected $_foo = 'bar';

   static public function test() {
      echo self::$_foo;
   }
}

class B extends A {
   static protected $_foo = 'baz';
}

B::test(); // outputs 'bar'

Если вы измените self немного, чтобы:

echo static::$_foo;

Затем сделайте:

B::test(); // outputs 'baz'

Так как self относится к классу, где $_foo был определен (А), в то время как static ссылается на класс, который вызвал его во время выполнения (B).

И, конечно, да, вы можете получить доступ к статическим защищенным элементам вне статического метода (т. Е. Контекста объекта), хотя видимость и область действия все еще имеют значение.

Статические переменные существуют в классе, а не в экземплярах класса. Вы можете получить к ним доступ из нестатических методов, вызывая их примерно так:

self::$_someVar

Это работает потому, что self является ссылкой на текущий класс, а не на текущий экземпляр (например, $this).

В порядке демонстрации:

<?
class A {
  protected static $foo = "bar";

  public function bar() {
    echo self::$foo;
  }
}

class B extends A { }

$a = new A();
$a->bar();

$b = new B();
$b->bar();
?>

Выход barbar, Однако, если вы попытаетесь получить к нему доступ напрямую:

echo A::$foo;

Тогда PHP будет правильно жаловаться на вас за попытку доступа к защищенному члену.

Другие вопросы по тегам