乘风原创程序

  • PHP 函数库精讲之类与对象
  • 2020/5/7 16:44:10
  • 废弃

    一些函数已经被废弃或者移除,请不要使用它们

    • __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",
    // ]