PHP教程

PHP静态关键字

在PHP中,static 关键字用于定义静态属性和静态方法。静态的属性和方法属于类本身,而不是类的某个特定的实例。这意味着无论创建了多少个类的实例,静态属性和方法只有一份。本教程详细介绍了用 static 关键字来定义静态方法和属性。

声明类属性或方法为静态后,就可以不实例化类而直接访问。在实例化的类对象中,也可以通过静态访问这些属性和方法。

一、静态方法

由于静态方法不需要通过对象即可调用,所以伪变量 $this 在静态方法中不可用。

静态方法示例:

<?php
class Foo {
    public static function aStaticMethod() {
        // ...
    }
}

Foo::aStaticMethod();
$classname = 'Foo';
$classname::aStaticMethod();
?>

注意:

  • 用静态方式调用一个非静态方法会抛出 Error;
  • 在 PHP 8.0.0 之前,通过静态方式调用一个非静态方法这种用法已经被废弃,并且会导致一个 E_DEPRECATED 级别的警告。

二、静态属性

静态属性使用范围解析操作符 ( :: )访问,不能通过对象操作符( -> )访问。通过变量来引用一个类是可行的,但这个变量的值不能是一个保留字 (例如self,parent和 static)。

静态属性示例:

<?php
class Foo
{
    public static $my_static = 'foo';

    public function staticValue() {
        return self::$my_static;
    }
}

class Bar extends Foo
{
    public function fooStatic() {
        return parent::$my_static;
    }
}


print Foo::$my_static . "\n";

$foo = new Foo();
print $foo->staticValue() . "\n";
print $foo->my_static . "\n";      // 未定义的 "属性" my_static

print $foo::$my_static . "\n";
$classname = 'Foo';
print $classname::$my_static . "\n";

print Bar::$my_static . "\n";
$bar = new Bar();
print $bar->fooStatic() . "\n";
?>

以上示例在 PHP 8 中的输出类似于:

foo
foo

Notice: Accessing static property Foo::$my_static as non static in /in/V0Rvv on line 23

Warning: Undefined property: Foo::$my_static in /in/V0Rvv on line 23

foo
foo
foo
foo

三、Late Static Bindings

static 关键字还有一个高级用途,称为 "后期静态绑定"。使用 static:: 而不是 self:: 调用时,它会引用到运行时最后调用的类名称,在继承上下文中非常有用。

class A {
    public static function who() {
        echo __CLASS__;
    }
    public static function test() {
        self::who(); // 在这里调用的是 A::who()
        static::who(); // 后期静态绑定,这里调用的是运行时最后的类名
    }
}

class B extends A {
    public static function who() {
        echo __CLASS__;
    }
}

B::test(); // 输出 B B,因为后期静态绑定使得 static::who() 调用了 B 中的 who 方法

使用静态成员是面向对象编程中的一种设计选择,它可以提供全局访问以及不依赖于类实例的方法和属性。然而,过度使用静态成员可能会导致代码难以测试和维护,因为它们引入了全局状态。

广告合作
QQ群号:707632017

温馨提示:

1、本网站发布的内容(图片、视频和文字)以原创、转载和分享网络内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。邮箱:2942802716#qq.com。(#改为@)

2、本站原创内容未经允许不得转裁,转载请注明出处“站长百科”和原文地址。

目录