是,ThinkPHP 6+ 默认使用 Composer 的 PSR-4 自动加载,支持 classmap 优化(dump-autoload -o 后为 O(1) 查找),非手动遍历;配置错误或未启用优化才会导致“加载慢”。
ThinkPHP 6+ 默认使用 composer 的 PSR-4 自动加载,不是自己手写的遍历查找。这意味着只要 composer.json 中的 autoload 配置正确,类文件路径和命名空间严格匹配,加载就是单次哈希查表,不扫描目录、不遍历文件。
但要注意:TP6 默认开启 classmap 优化(composer dump-autoload -o 生成的 vendor/composer/autoload_classmap.php),这个映射表是静态数组,比 PSR-4 规则解析更快——尤其在大量类场景下。
composer dump-autoload -o:走 PSR-4 规则,需拼路径 + file_exists() 判断,略慢-o:直接查 classmap 数组,O(1) 查找,最快think\Loader):已废弃,别再用,性能差且不兼容 Composer 生态真实瓶颈往往不在自动加载本身,而在你测量方式或环境干扰。比如:
debug 模式 + 日志记录类加载过程:TP6 的 think\facade\Log 在 debug 下可能同步写文件,掩盖了真实加载耗时new 同一个类:PHP 会缓存已加载的类定义,第二次以后基本不走 autoload —— 你测的其实是构造函数或依赖注入开销绕过框架生命周期,用最小上下文测原始 autoload 行为:
require 'vendor/autoload.php';// 清空 OPCache(仅开发环境) opcache_reset();
// 强制触发 autoload(不 new,避免实例化开销) $start = microtime(true); spl_autoload_call('app\controller\Index'); $end = microtime(true);
echo 'autoload time: ' . (($end - $start) * 1000) . " ms\n";
关键点:
class_exists() 测:它默认不会触发 autoload,除非第二个参数为 true
get_declared_classes() 前后对比)composer dump-autoload -o 前后数据,差距通常在 0.02ms → 0.003ms 级别PSR-4 匹配失败时,Composer 会 fallback 到扫描 psr-0 和 files 等其他规则,甚至逐个尝试所有 autoloaders —— 这才是真正的慢源。
检查你的 composer.json 是否符合规范:
"autoload": {
"psr-4": {
"app\\": "app/"
}
}对应类 app\controller\Index 必须存在路径 app/controller/Index.php,且文件内声明 namespace app\controller;。任何大小写错误、斜杠方向错误、多一层目录(如 app/Controller/Index.php 但 n

app\controller)都会让 PSR-4 失败,触发兜底逻辑。
验证方式:
composer dump-autoload -vvv,看输出中是否列出你的类vendor/composer/autoload_psr4.php,确认 app\\ 映射到了正确的绝对路径composer show --platform 确保没有冲突的全局 autoload 配置自动加载本身不是瓶颈,但配置错、测不准、环境脏,会让结果完全失真。真正该盯的是 classmap 是否生成、OPcache 是否启用、路径命名是否零误差。