廢棄
一些函式已經被廢棄或者移除,請不要使用它們
__autoload
- 7.2 版本廢棄call_user_method_array
- 7.0 版本移除call_user_method
- 7.0 版本移除
判斷
類的存在性檢查
相關函式
class_exists
- 判斷類是否存在interface_exists
- 判斷介面是否存在trait_exists
- 判斷 Trait 是否存在
第二個引數用來決定如果尚未載入,是否使用自動載入。
class_exists ( string $class_name [, bool $autoload = true ] ) : bool
interface_exists ( string $interface_name [, bool $autoload = true ] ) : bool
trait_exists ( string $traitname [, bool $autoload = true ] ) : bool
示例 - 廣泛的類存在性檢查函式
function common_class_exists(string $class): bool
{
return class_exists($class, false) || interface_exists($class, false) || trait_exists($class, false);
}
類成員的存在性檢查
相關函式:
property_exists
- 檢查屬性是否存在method_exists
— 檢查方法是否存在
method_exists ( mixed $object , string $method_name ) : bool
property_exists ( mixed $class , string $property ) : bool
示例 - 實現一個回撥函式,使用者可通過方法或者屬性來定義回撥的 URL
trait RedirectsUsers
{
public function redirectPath()
{
if (method_exists($this, 'redirectTo')) {
return $this->redirectTo();
}
return property_exists($this, 'redirectTo') ? $this->redirectTo : '/home';
}
}
類關係判斷
相關函式:
is_a
— 物件屬於該類或該類的父類,返回TRUE
is_subclass_of
— 物件是該類的子類,返回 TRUE
is_a ( object $object , string $class_name [, bool $allow_string = FALSE ] ) : bool
is_subclass_of ( object $object , string $class_name ) : bool
示例
interface A {}
interface B {}
class BaseFoo implements B {}
class Foo extends BaseFoo implements A{}
$foo = new Foo();
// 物件
is_a($foo, 'BaseFoo'); // true
is_a($foo, 'Foo'); // true
is_a($foo, 'A'); // true
// 類
is_a('Foo', 'BaseFoo'); // false
is_a('Foo', 'BaseFoo', true); // true, 傳入第三個引數,代表允許使用類名而不是示例
is_subclass_of($foo, 'Foo'); // false
is_subclass_of($foo, 'BaseFoo'); // true
is_subclass_of($foo, 'B'); // true
實際情況中,更多的是使用操作符 instanceof
$foo instanceof Foo; // true
$foo instanceof A; // true
$foo instanceof B; // true
操作
相關函式:
class_alias()
- 為一個類建立別名
class_alias ( string $original , string $alias [, bool $autoload = TRUE ] ) : bool
示例 - 類別名載入器,用於管理類的別名
class AliasLoader
{
private $aliases;
public function __construct(array $aliases)
{
$this->aliases = $aliases;
}
public function load($alias)
{
if (isset($this->aliases[$alias]))
{
return class_alias($this->aliases[$alias], $alias);
}
}
}
class LongLongLongLongFoo {}
$aliases = [
'Foo' => 'LongLongLongLongFoo',
'Bar' => 'LongLongLongLongBar',
];
$loader = new AliasLoader($aliases);
$loader->load('Foo');
$foo = new Foo();
var_dump($foo); // object(LongLongLongLongFoo)#3395
獲取
獲取全部
相關函式:
get_declared_traits
— 返回所有已定義的 traits 的陣列get_declared_interfaces
— 返回一個陣列包含所有已宣告的介面get_declared_classes
— 返回由已定義類的名字所組成的陣列
這些函式在實際中很少需要用到
foreach (get_declared_classes() as $class) {
$r = new \ReflectionClass($class);
}
獲取類
相關函式
get_called_class
— 後期靜態繫結類的名稱,在類外部使用返回 false
get_class
— 返回物件的類名get_parent_class
— 返回物件或類的父類名
get_called_class ( void ) : array
get_class ([ object $object = NULL ] ) : string
get_parent_class ([ mixed $obj ] ) : string
示例 - 丟擲異常時獲取異常的類
throw (new ModelNotFoundException)->setModel(get_called_class());
獲取類成員
相關函式:
- get_class_methods — 返回由類的方法名組成的陣列
- get_class_vars — 返回由類的預設屬性組成的陣列
- get_object_vars — 返回由物件屬性組成的關聯陣列
示例 - 獲取類中的所有訪問器屬性
class Foo {
public function getFullNameAttribute()
{
}
public function getTextAttribute()
{
}
public static function getMutatorMethods()
{
preg_match_all('/(?<=^|;)get([^;]+?)Attribute(;|$)/', implode(';', get_class_methods(static::class)), $matches);
return $matches[1];
}
}
Foo::getMutatorMethods()
// [
// "FullName",
// "Text",
// ]
本作品採用《CC 協議》,轉載必須註明作者和本文連結