類的靜態成員與一般的類成員不同: 靜態成員與對象的實例無關,只與類本身有關。他們用來實現類要封裝的功能和數據,但不包括特定對象的功能和數據,靜態成員包括靜態方法和靜態屬性。
靜態屬性包含在類中要封裝的數據,可以由所有類的實例共享。實際上,除了屬於一個固定的類並限制訪問方式外,類的靜態屬性非常類似於函數的全局變量。
我們在下例中使用了一個靜態屬性Counter::$count。它屬於Counter類,而不屬於任何Counter的實例。你不能用this來引用它,但可以用self或其它有效的命名表達。在例子中,getCount方法返回self::$count,而不是Counter::$count。
靜態方法則實現類需要封裝的功能,與特定的對象無關. 靜態方法非常類似於全局函數. 靜態方法可以完全訪問類的屬性,也可以由對象的實例來訪問,不論訪問的限定語是否是什麼.
在前文的例子中,getCount是一個普通的方法,用->來調用. PHP建立一個this變量,盡管方法沒有使用到.但是,getCount不屬於任何對象.在有些情況下,我們甚至希望在不存在有效的對象時調用它,那麼就應該使用靜態方法. PHP將不在靜態方法內部建立this變量,即使你從一個對象中調用它們.
例子6.7由6.3改變getCount為靜態方法而來. Static關鍵字不能阻止一個實例用->運算符來調用getCount,但PHP將不在方法內部建立this變量.如果你使用this->來調用,將會出錯.
//6.3例指第四節--構造函數和析構函數中的例子(參看前文),通過兩個例子的比較,你可以很好掌握
//static方法與普通方法之間的區別.
你可以寫一個方法通過判斷this是否建立來顯示是否它被靜態地或者非靜態地調用. 當然,如果你用了static 關鍵字,不管它怎樣被調用,這個方法總是靜態的.
你的類也可以定義常量屬性,不需要使用public static,只需要用const關鍵字即可. 常量屬性總是靜態的.它們是類的屬性,而不是實例化該類的對象的屬性.
Listing 6.7 Static members
class Counter
{
private static $count = 0;
const VERSION = 2.0;
function __construct()
{
self::$count++;
}
function __destruct()
{
self::$count--;
}
static function getCount()
{
return self::$count;
}
};
//創建一個實例,則__construct()將執行
$c = new Counter();
//輸出 1
print(Counter::getCount() . "n");
//輸出類的版本屬性
print("Version used: " . Counter::VERSION . "n");
?>