Pull to refresh

Позднее статическое связывание в PHP (Часть I)

Reading time2 min
Views35K
phpПозднее Статическое Связывание (Late Static Binding, LSB) является бурно темой обсуждений последние три года в кругах разработчиков PHP (и наконец мы его получили в PHP 5.3). Но зачем оно нужно? В данной статье, как раз и будет рассматриваться, как позднее статическое связывание может значительно упростить ваш код.

На встрече разработчиков PHP, которая проходила в Париже в ноябре 2005 года, тема позднего статического связывания официально обсуждалась основной командой разработчиков. Они согласились реализовать его, наряду со многими другими темами, которые стояли на повестке дня. Детали должны были быть согласованы в ходе открытых дискуссий.

С тех пор как позднее статическое связывание было объявлено как грядущая фишка, прошло два года. И вот наконец LSB стало доступно для использования в PHP 5.3. Но это событие прошло незаметно для разработчиков использующих PHP, из заметок только страничка в мануале.

Если кратко, новая функциональность позднего статического связывания, позволяет объектам все также наследовать методы у родительских классов, но помимо этого дает возможность унаследованным методам иметь доступ к статическим константам, методам и свойствам класса потомка, а не только родительского класса. Давайте рассмотрим пример:

class Beer {
    const NAME = 'Beer!';
      public function getName() {
          return self::NAME;
    }
}
class Ale extends Beer {
	const NAME = 'Ale!';
}

$beerDrink = new Beer;
$aleDrink = new Ale;

echo "Beer is: " . $beerDrink->getName() ."\n";
echo "Ale is:  " . $aleDrink->getName()  ."\n";


Этот код выдаст такой результат:

Beer is: Beer!
Ale is:  Beer!


Класс Ale унаследовал метод getName(), но при этом self все еще указывает на класс в котором оно используется (в данном случае это класс Beer). Это осталось и в PHP 5.3, но добавилось слово static. И снова рассмотрим пример:

class Beer {
  const NAME = 'Beer!';
  public function getName() {
	  return self::NAME;
  }
  public function getStaticName() {
	  return static::NAME;
  }
}

class Ale extends Beer {
  const NAME = 'Ale!';
}

$beerDrink = new Beer;

$aleDrink = new Ale;

echo "Beer is: " . $beerDrink->getName() ."\n";
echo "Ale is:  " . $aleDrink->getName()  ."\n";

echo "Beer is actually: " . $beerDrink->getStaticName() ."\n";
echo "Ale is actually:  " . $aleDrink->getStaticName()  ."\n";


Новое ключевое слово static указывает, что необходимо использовать константу унаследованного класса, вместо константы которая была определена в классе где объявлен метод getStaticName(). Слово static было добавлено, чтобы реализовать новый функционал, а для обратной совместимости self работает также как и в предыдущих версиях PHP.

Внутренне, основное отличие (и, собственно, причина почему связывание назвали поздним) между этими двумя способами доступа, в том, что PHP определят значение для self::NAME во время «компиляции» (когда симовлы PHP преобразуются в машинный код, который будет обрабатываться движком Zend), а для static::NAME значение будет определено в момент запуска (в тот момент, когда машинный код будет выполнятся в движке Zend).

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

UPDATE: Вторая часть статьи. Практический пример.

VIA: Позднее статическое связывание в PHP (Часть I)

Перевод вот этого: Late Static Binding: a practical example
Tags:
Hubs:
Total votes 33: ↑32 and ↓1+31
Comments53

Articles