0

在第一种情况下,我们在对象上下文中调用函数。在第二种情况下,我们有类上下文。parent:: 是否根据上下文同时像这样和 self 一样工作?

class par_parent{
    private $var='value1';
    private static $val='value2';
    public function call(){
        var_dump('Object '.$this->var);
    }
    public static function staticCall(){
        var_dump('Static '.self::$val);
    }
}

class par_child extends par_parent{
    public function callObj(){
        parent::call();
    }

    public static function callStatic(){
        parent::staticCall();
    }
}



$obj=new par_child();
$obj->callObj();
**//string 'Object value1' (length=13)**
par_child::callStatic();
**//string 'Static value2' (length=13)**
4

1 回答 1

0

parent::像关键字一样被绑定,self::总是看到它被定义代码的上下文,而不是从它被调用的地方,所以本质上它就像self::关键字一样工作。如果您需要它像$this使用提供的后期静态绑定一样工作static::。考虑这个例子:

class A { 
    protected static $v = 'a';
    public static function staticsay() {
        print static::$v;
    }

}
class B extends A { 
    protected static $v = 'b';
    public static function say(){
        print parent::$v;
    }
}
class C extends B { 
    protected static $v = 'c';
    public static function selfsay(){
        print parent::$v;
    }
} 

C::say(); // prints 'a'
C::selfsay(); // prints 'b'
C::staticsay(); // prints 'c'

在这里,我们调用它的say()方法C来自类B,所以它的parent::意思AA::$v'a',所以它打印出来。

虽然parent::inC指向类B并且它认为它$v是'b'。

php 5.3 附带了后期静态绑定和static::关键字,可让您访问static基类静态方法中的变量和方法,以便从类中A::staticsay看到。$vC

于 2012-09-06T18:43:14.883 回答