Есть ли середина между собой и статичным?
Я ищу золотую середину между SELF и STATIC, без неожиданного поведения позднего статического связывания.
Ниже мой код с результатами практики и ожидаемыми результатами:
<?php
class A {
public function get_self() {
return new self();
}
public function get_static() {
return new static();
}
}
class B extends A {}
class C {
public function static_get_a_self() {
return A::get_self();
}
public function static_get_a_static() {
return A::get_static();
}
public function var_get_a_self() {
$a = new A();
return $a->get_self();
}
public function var_get_a_static() {
$a = new A();
return $a->get_static();
}
public function static_get_b_self() {
return B::get_self();
}
public function static_get_b_static() {
return B::get_static();
}
public function var_get_b_self() {
$b = new B();
return $b->get_self();
}
public function var_get_b_static() {
$b = new B();
return $b->get_static();
}
}
$a = new A();
$b = new B();
$c = new C();
echo "Static calls: \n";
echo "B::get_self() ============= " . get_class(B::get_self()) . " | expected A \n";
echo "B::get_static() =========== " . get_class(B::get_static()) . " | expected B \n";
echo "A::get_static() =========== " . get_class(A::get_static()) . " | expected A \n";
echo "\n";
echo "Object Calls on A: \n";
echo '$a->get_self() ============ ' . get_class($a->get_self()) . " | expected A \n";
echo '$a->get_static() ========== ' . get_class($a->get_static()) . " | expected A \n";
echo "\n";
echo "Object Calls on B: \n";
echo '$b->get_self() ============ ' . get_class($b->get_self()) . " | expected A \n";
echo '$b->get_static() ========== ' . get_class($b->get_static()) . " | expected B \n";
echo "\n";
echo "C Object Calls on A: \n";
echo "Internally against A::{call}\n";
echo '$c->static_get_a_self() === ' . get_class($c->static_get_a_self()) . " | expected A \n";
echo '$c->static_get_a_static() = ' . get_class($c->static_get_a_static()) . " | expected A < Whoa! \n";
echo "Internally against \$a = new A();\n";
echo '$c->var_get_a_self() ====== ' . get_class($c->var_get_a_self()) . " | expected A \n";
echo '$c->var_get_a_static() ==== ' . get_class($c->var_get_a_static()) . " | expected A \n";
echo "\n";
echo "C Object Calls on B: \n";
echo "Internally against B::{call}\n";
echo '$c->static_get_b_self() === ' . get_class($c->static_get_b_self()) . " | expected A \n";
echo '$c->static_get_b_static() = ' . get_class($c->static_get_b_static()) . " | expected B < Whoa! \n";
echo "Internally against \$b = new B();\n";
echo '$c->var_get_b_self() ====== ' . get_class($c->var_get_b_self()) . " | expected A \n";
echo '$c->var_get_b_static() ==== ' . get_class($c->var_get_b_static()) . " | expected B \n";
?>
Результаты, достижения:
Static calls:
B::get_self() ============= A | expected A
B::get_static() =========== B | expected B
A::get_static() =========== A | expected A
Object Calls on A:
$a->get_self() ============ A | expected A
$a->get_static() ========== A | expected A
Object Calls on B:
$b->get_self() ============ A | expected A
$b->get_static() ========== B | expected B
C Object Calls on A:
Internally against A::{call}
$c->static_get_a_self() === A | expected A
$c->static_get_a_static() = C | expected A < Whoa!
Internally against $a = new A();
$c->var_get_a_self() ====== A | expected A
$c->var_get_a_static() ==== A | expected A
C Object Calls on B:
Internally against B::{call}
$c->static_get_b_self() === A | expected A
$c->static_get_b_static() = C | expected B < Whoa!
Internally against $b = new B();
$c->var_get_b_self() ====== A | expected A
$c->var_get_b_static() ==== B | expected B
Этот вид имеет смысл, в позднем статическом связывании зарезервированная "статическая" переменная ссылается на последнюю область класса. Я ищу зарезервированную переменную, которая относится к верхнему классу, в котором эта переменная встречается.
IE: если я расширяю класс RecordObject классом Member, мне нужна функция, которую я могу определить в RecordObject, которая будет создавать новый Member (или Page, или Comment) без необходимости перезаписывать эту функцию в каждом определении класса. Это возможно?
Проблема, с которой я сталкиваюсь, заключается, скажем, в том, что я нахожусь в Member, и я вызываю Page::get($id), которая внутренне создает новый объект и делает некоторую магию. К сожалению, если я использую static, этот новый объект является членом... Никаких кубиков.
1 ответ
Почему вы игнорируете строгие ошибки?
Просто добавь static
ключевое слово для статических методов.
class A {
static public function get_self() {
return new self();
}
static public function get_static() {
return new static();
}
}
И все должно быть как положено.