stdClass類是PHP的一個內部保留類,初始時沒有成員變數也沒成員方法,所有的魔術方法都被設定為NULL,可以使用其傳遞變數參數,但是沒有可以呼叫的方法。 stdClass類別可以被繼承,只是這樣做沒有什麼意義。
該類別是PHP的保留類,並非所有類別的基底類別。
<?php class foo {} $bar = new foo(); echo $bar instanceof stdClass?'yes':'no'; //output:no
另一個例子:
<?php // CTest does not derive from stdClass class CTest { public $property1; } $t = new CTest; var_dump($t instanceof stdClass); // false var_dump(is_subclass_of($t, 'stdClass')); // false echo get_class($t) . "\n"; // 'CTest' echo get_parent_class($t) . "\n"; // false (no parent) ?>
任何用(object)強制轉換都會得到一個stdClass的實例。
理解PHP中的stdClass類
stdClass在PHP5才開始被流行。而stdClass也是zend的保留類別。 stdClass是PHP的一個基類,
所有的類別幾乎都繼承這個類,所以任何時候都可以被new,可以讓這個變數成為一個object。同時,
這個基底類別又有一個特殊的地方,就是沒有方法。凡是用new stdClass()的變量,
都不可能出現$a->test()這種方式的使用。 PHP5的物件的獨特性,物件在任何地方被調用,
都是引用位址型的,所以相對消耗的資源會少一點。在其它頁面為它賦值時是直接修改,而不是引用一個拷貝。
以上的定義大多都是正確的,但是一個致命性的診斷錯誤: stdClass是PHP的一個基類,所有的類別幾乎都繼承這個類別。 看一個簡單的例子:
class EmptyClass { } $object = new EmptyClass(); if ($object instanceof stdClass) { echo 'yes'; }else{ echo 'no'; }
執行程式碼,輸出”no”,這個例子充分說明了stdClass類別並不是所有類別的基底類別。它只是PHP的一個保留類,或者說一個類似strlen函數這樣的一個角色。 我們從原始碼的維度看看stdClass類別的實現,它註冊的位置在 Zend/zend_buildin_functions.c檔案中。如下:
ZEND_MINIT_FUNCTION(core) { /* {{{ */ zend_class_entry class_entry; /* 注册stdClass 类 */ INIT_CLASS_ENTRY(class_entry, "stdClass", NULL); zend_standard_class_def = zend_register_internal_class(&class_entry TSRMLS_CC); /* 注册默认类,接口,如Exception类,SPL中的一些类等 */ zend_register_default_classes(TSRMLS_C); return SUCCESS; } /* }}} */
這是zend_builtin_module的模組初始化函數,在PHP核心進行模組初始化操作時會自動載入這個函數, 這樣,stdClass類別的註冊操作也就會被執行了。從這段程式碼可以看出,stdClass類別是一個沒有成員變數也沒有成員方法的類別。 它的所有的魔術方法,父類別、介面等在初始化時都會設定為NULL。由於在PHP中對於一個類別我們無法動態的新增方法, 所以這個類別只能用來處理動態屬性,這也是我們一個常見的用法。
總結:
stdClass類是PHP的一個內部保留類,初始時沒有成員變數也沒成員方法,所有的魔術方法都被設定為NULL,可以使用其傳遞變數參數,但是沒有可以呼叫的方法。 stdClass類別可以被繼承,只是這樣做沒有什麼意義。
更多PHP5新增stdClass 內部保留類相關文章請關注PHP中文網!