Gdy lewa część jest instancją obiektu, używasz ->
. W przeciwnym razie korzystasz ::
.
Oznacza to, że ->
jest najczęściej używany do uzyskiwania dostępu do członków instancji (chociaż może być również używany do uzyskiwania dostępu do członków statycznych, takie użycie jest odradzane), podczas gdy ::
zwykle jest używany do uzyskiwania dostępu do członków statycznych (chociaż w kilku szczególnych przypadkach jest używany do uzyskiwania dostępu do członków instancji ).
Na ogół ::
stosuje się do uchwały zakres i może mieć albo nazwą klasy parent
, self
lub (w PHP 5.3) static
z jego lewej strony. parent
odnosi się do zakresu nadklasy klasy, w której jest używana; self
odnosi się do zakresu klasy, w której jest używany; static
odnosi się do „wywoływanego zakresu” (patrz późne wiązania statyczne ).
Zasadą jest, że połączenie z ::
jest wywołaniem instancji wtedy i tylko wtedy, gdy:
- metoda docelowa nie jest zadeklarowana jako statyczna i
- w chwili wywołania istnieje zgodny kontekst obiektowy, co oznacza, że muszą być prawdziwe:
- połączenie jest wykonywane z kontekstu, w którym
$this
istnieje i
- klasa
$this
jest albo klasą wywoływanej metody, albo jej podklasą.
Przykład:
class A {
public function func_instance() {
echo "in ", __METHOD__, "\n";
}
public function callDynamic() {
echo "in ", __METHOD__, "\n";
B::dyn();
}
}
class B extends A {
public static $prop_static = 'B::$prop_static value';
public $prop_instance = 'B::$prop_instance value';
public function func_instance() {
echo "in ", __METHOD__, "\n";
/* this is one exception where :: is required to access an
* instance member.
* The super implementation of func_instance is being
* accessed here */
parent::func_instance();
A::func_instance(); //same as the statement above
}
public static function func_static() {
echo "in ", __METHOD__, "\n";
}
public function __call($name, $arguments) {
echo "in dynamic $name (__call)", "\n";
}
public static function __callStatic($name, $arguments) {
echo "in dynamic $name (__callStatic)", "\n";
}
}
echo 'B::$prop_static: ', B::$prop_static, "\n";
echo 'B::func_static(): ', B::func_static(), "\n";
$a = new A;
$b = new B;
echo '$b->prop_instance: ', $b->prop_instance, "\n";
//not recommended (static method called as instance method):
echo '$b->func_static(): ', $b->func_static(), "\n";
echo '$b->func_instance():', "\n", $b->func_instance(), "\n";
/* This is more tricky
* in the first case, a static call is made because $this is an
* instance of A, so B::dyn() is a method of an incompatible class
*/
echo '$a->dyn():', "\n", $a->callDynamic(), "\n";
/* in this case, an instance call is made because $this is an
* instance of B (despite the fact we are in a method of A), so
* B::dyn() is a method of a compatible class (namely, it's the
* same class as the object's)
*/
echo '$b->dyn():', "\n", $b->callDynamic(), "\n";
Wynik:
B :: $ prop_static: B :: $ prop_static wartość
B :: func_static (): w B :: func_static
$ b-> prop_instance: B :: $ prop_instance wartość
$ b-> func_static (): w B :: func_static
$ b-> func_instance ():
w B :: func_instance
w A :: func_instance
w A :: func_instance
$ a-> dyn ():
w A :: callDynamic
w dynamicznym dyn (__callStatic)
$ b-> dyn ():
w A :: callDynamic
w dynamicznym dyn (__call)