get_declared_classes

(PHP 4, PHP 5, PHP 7, PHP 8)

get_declared_classes返回包含已定义类的名称的数组

描述

get_declared_classes(): array

获取已声明的类。

参数

此函数没有参数。

返回值

返回当前脚本中已声明类的名称的数组。

注意:

请注意,根据您已编译或加载到 PHP 中的扩展,可能存在其他类。这意味着您将无法使用这些名称定义您自己的类。附录的 预定义类 部分列出了预定义类。

变更日志

版本 描述
7.4.0 以前 get_declared_classes() 始终在子类之前返回父类。现在不再是这样。get_declared_classes() 返回值的顺序没有保证。

示例

示例 #1 get_declared_classes() 示例

<?php
print_r
(get_declared_classes());
?>

上面的示例将输出类似于

Array
(
    [0] => stdClass
    [1] => __PHP_Incomplete_Class
    [2] => Directory
)

参见

添加注释

用户贡献的注释 10 个注释

匿名
19 年前
关于 3-21 的注释

<?php

class myclass {}

$class = 'myclass';
$instance = new $class();

?>

此函数还可用于通过在 include 之前和之后调用它来确定特定文件中定义的类的名称。它绝非无用函数。
rmamdaminov at gmail dot com
9 个月前
请注意,此函数还计算枚举。

<?php

enum Bla
{
case
Foo;
}

var_dump(get_declared_classes());
?>

结果
array(116) {
...
[115]=> string(3) "Bla"
}
matt-php at DONT-SPAM-ME dot bitdifferent dot com
19 年前
此函数返回的数组将按照定义/包含/需要类的顺序排列,并且此顺序似乎不会改变。

例如

<?PHP

//定义 classone
class classone { }

//定义 classtwo
class classtwo { }

//这将显示 X 个类(内置的、扩展的等),其中 classone 和 classtwo 作为最后两个元素

print_r(get_declared_classes());

//定义 classthree
class classthree { }

//...和 four
class classfour { }

//显示与之前相同的结果,附加了 class three 和 four
print_r(get_declared_classes());

?>

输出

数组
(
[0] => stdClass
[1] ....其他已定义的类....
[10] => classone
[11] => classtwo
)

以及...

数组
(
[0] => stdClass
[1] ....其他已定义的类....
[10] => classone
[11] => classtwo
[12] => classthree
[13] => classfour
)
dexen + goofy _ pl
16 年前
摘要
* 在 PHP 5.1 中,类名保留大小写
* 相反,在 PHP 4.4 中,类名被转换为小写,除了少数内置类

从 PHP 5.1 系列(可能也包括 5.0,但我目前无法测试它)开始,get_declared_classes() 函数返回保留大小写的名称列表。由于 PHP 通常在类名方面不区分大小写,因此这可能出乎意料。此外,这可能会破坏假设小写列表的旧代码。

在检查类是否存在时要格外小心。以下示例可能容易出错:<?php in_array( $className, $classget_declared_classes() ) ?>

一种可靠(虽然速度较慢)的方法是遍历数组并将大小写规范化为小写,例如

<?php
$exists
= FALSE;
$className = strtolower( $className );
foreach (
get_declared_classes() as $c ) {
if (
$className === strtolower( $c ) ) {
$exists = TRUE;
break;
}
}
?>

以上代码片段的优化留作简单练习供读者完成;)
-- dexen deVries
brain at code dot com
10 年前
如果您可能在以后的生产环境中将类文件合并到一个包文件中,那么 get-declared-classes 根本没有意义。

假设:package.php
print_r(get_declared_classes());
class declaredHere { }
print_r(get_declared_classes());

因此,在这种情况下,declaredHerr 类是在第一次调用 print_r() 时定义的。
因为 PHP 编译器运行整个文件并在运行代码之前声明内容。

但是(可爱的 PHP)
print_r(get_declared_classes());
if(true){
class declaredHere { }
}
print_r(get_declared_classes());
将只在第二次 print_r 中打印 declaredHere 类。

这不是错误,而是一个...
matt at mattsoft dot net
18 年前
类无法卸载。可能在未来的版本中实现这一点不太实际。如果我是 Zend,我不会费心去实现它。您最好找到解决方法。找到一种解决方法,避免这样做是更好的编程技术。

http://www.zend.com/zend/week/week223.php#Heading10
smokey
21 年前
您无法删除它们。它们是“已定义的”,这在解析器从类加载类时发生。您只是删除了一个类的实例。
dcahh at gmx de
16 年前
此函数只考虑类和子类。不考虑子子类。

事实上,我的代码提供了抽象类,然后是使用此抽象类的类。此外,我的具体类还有子类 - 这就是为什么我的子类未列入返回数组中的原因。
Jazeps Basko
20 年前
在 PHP5 中,您无法通过调用此函数获取已声明的接口!!!
要获取接口,您应该使用 get_declared_interfaces()。但是,要检查接口是否已定义,您应该使用 class_exists()!这很奇怪,但 PHP 团队不这么认为。
yarco dot wang at gmail dot com
10 年前
上面的评论太旧了。
现在,无论顺序如何,输出都将相同

<?php
class Test1
{}

print_r(get_declared_classes());

class
Test2
{}

print_r(get_declared_classes());

?>

将输出相同的结果。
To Top