对象和类操作符

可以使用对象运算符(->)和类运算符(::)访问对象或类的成员。

class MyClass {
    public $a = 1;
    public static $b = 2;
    const C = 3;
    public function d() { return 4; }
    public static function e() { return 5; }
}

$object = new MyClass();
var_dump($object->a);   // int(1)
var_dump($object::$b);  // int(2)
var_dump($object::C);   // int(3)
var_dump(MyClass::$b);  // int(2)
var_dump(MyClass::C);   // int(3)
var_dump($object->d()); // int(4)
var_dump($object::d()); // int(4)
var_dump(MyClass::e()); // int(5)
$classname = "MyClass";
var_dump($classname::e()); // also works! int(5)

请注意,在对象操作符之后,不应该写入 $$object->a 而不是 $object->$a)。对于类操作符,情况并非如此,并且 $ 是必需的。对于类中定义的常量,从不使用 $

另请注意,仅当 d() 函数引用对象时才允许 var_dump(MyClass::d());

class MyClass {
    private $a = 1;
    public function d() {
        return $this->a;
    }
}

$object = new MyClass();
var_dump(MyClass::d());   // Error!

这会导致’PHP 致命错误:未捕获错误:在不在对象上下文中时使用$ this'

这些运算符具有关联性,可用于链接

class MyClass {
    private $a = 1;
    
    public function add(int $a) {
        $this->a += $a;
        return $this;
    }
    
    public function get() {
        return $this->a;
    }
}

$object = new MyClass();
var_dump($object->add(4)->get());  // int(5)

这些运算符具有最高优先级(手册中甚至没有提到它们),甚至高于 clone。从而:

class MyClass {
    private $a = 0;
    public function add(int $a) {
        $this->a += $a;
        return $this;
    }
    public function get() {
        return $this->a;
    }
}

$o1 = new MyClass();
$o2 = clone $o1->add(2);
var_dump($o1->get()); // int(2)
var_dump($o2->get()); // int(2)

在克隆对象之前添加 $o1 的值 !

请注意,使用括号来影响优先级不适用于 PHP 5 及更早版本(在 PHP 7 中):

// using the class MyClass from the previous code
$o1 = new MyClass();
$o2 = (clone $o1)->add(2);  // Error in PHP 5 and before, fine in PHP 7
var_dump($o1->get()); // int(0) in PHP 7
var_dump($o2->get()); // int(2) in PHP 7