Не можете вызвать статический метод из класса как имя переменной? - PullRequest
7 голосов
/ 24 сентября 2010

Я использую php 5.2.6. У меня есть шаблон стратегии, а у стратегий есть статический метод. В классе, который фактически реализует одну из стратегий, он получает имя класса стратегии для создания экземпляра. Тем не менее, я хотел вызвать один из статических методов до создания экземпляра, например:

$strNameOfStrategyClass::staticMethod();

но это дает T_PAAMAYIM_NEKUDOTAYIM.

$> cat test.php

<?

interface strategyInterface {
        public function execute();
        public function getLog();
        public static function getFormatString();
}


class strategyA implements strategyInterface {
        public function execute() {}
        public function getLog() {}
        public static function getFormatString() {}
}

class strategyB implements strategyInterface {
        public function execute() {}
        public function getLog() {}
        public static function getFormatString() {}
}

class implementation {
        public function __construct( strategyInterface $strategy ) {
                $strFormat = $strategy::getFormatString();
        }
}

$objImplementation = & new implementation("strategyB") ;

$> php test.php

Parse error: syntax error, unexpected T_PAAMAYIM_NEKUDOTAYIM in /var/www/test.php on line 24

$> php -v

PHP 5.2.6-1+lenny9 with Suhosin-Patch 0.9.6.2 (cli) (built: Aug  4 2010 03:25:57)

Будет ли это работать в 5,3?

Ответы [ 2 ]

12 голосов
/ 24 сентября 2010

Да. Этот синтаксис был введен в 5.3

Чтобы обойти <= 5.2, вы можете использовать <code>call_user_func:

call_user_func(array($className, $funcName), $arg1, $arg2, $arg3);

или call_user_func_array:

call_user_func_array(array($className, $funcName), array($arg1, $arg2, $arg3));

Но с другой стороны, то, что вы пытаетесь сделать, на самом деле не имеет смысла ...

Почему это статическая функция? Ваш конструктор в implementation все равно ожидает объект (это то, что ищет strategyInterface $strategy). Передача строки не будет работать, так как строки не реализуют интерфейсы. Итак, я бы сделал интерфейс нестатичным, а затем сделал бы что-то вроде:

$strategy = new StrategyB();
$implementation = new Implementation($strategy);

Тогда в конструкторе:

$strFormat = $strategy->getFormatString();

Или, если вы действительно хотите, чтобы этот метод был статическим, вы можете сделать:

$strFormat = call_user_func(array(get_class($strategy), 'getFormatString'));

Да, и = & new Синакс устарел (и в любом случае не делает то, что вы думаете, что он делает).

0 голосов
/ 24 сентября 2010

Тип подсказки даст вам несколько проблем:

Аргумент 1 передан реализация :: __ construct () должен реализовать интерфейс стратегииInterface, заданная строка

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...