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類可以被繼承,只是這樣做沒有什麼意義。
官方手冊參考:http://www.php.net/manual/en/language.oop5.basic.php#92123