调用类常量时PHP Autoloader会加载吗?

调用类常量时PHP Autoloader会加载吗?,php,autoloader,Php,Autoloader,我有一个类,它定义了一些类常量。为了简单起见,它看起来有点像这个假的类 class MyThing { const BORIS = 'Yeltsin'; } 我正在注册类所在的目录,如下所示 AutoLoader::registerDirectory('lib'); 我使用的是PHP的autoloader,它可以正常工作,除非我试图调用这个类const 如果我这样做 MyThing::BORIS 我明白了 Undefined class constant 'BORIS' 我想这就是自

我有一个类,它定义了一些类常量。为了简单起见,它看起来有点像这个假的类

class MyThing {
  const BORIS = 'Yeltsin';
}
我正在注册类所在的目录,如下所示

AutoLoader::registerDirectory('lib');
我使用的是PHP的autoloader,它可以正常工作,除非我试图调用这个类const

如果我这样做

MyThing::BORIS
我明白了

Undefined class constant 'BORIS'
我想这就是自动装弹机的工作原理,但我想知道我是否正确

我正在使用这个自动加载器类,它是在我开始在这家公司工作之前选择的,但它似乎有效

<?php

/**
 * Autoloading class.
 * From http://jes.st/2011/phpunit-bootstrap-and-autoloading-classes/
 * as per the author comment:
 * Jess Telford says:
 *   December 21, 2013 at 4:01 am
 *   Public Domain – do with it whatever you want :)
 *
 * This class will compare classnames to the filename without extensions (.class.php or .php) registered
 *
 * This means that only a class per file can be loaded and only if the class name is identical (case sensitive) to the file name
 *
 */

class AutoLoader {

    static private $classNames = array();

    /**
     * Recursively store all .class.php and .php files found under $dirName in the autoloader
     *
     * @param String $dirName has to be a valid path
     */
    public static function registerDirectory($dirName) {

        $di = new DirectoryIterator($dirName);
        foreach ($di as $file) {

            if ($file->isDir() && !$file->isLink() && !$file->isDot()) {
                self::registerDirectory($file->getPathname());
            } elseif (substr(strtolower ($file->getFilename()), -10) === '.class.php') {
                $className = substr($file->getFilename(), 0, -10);
                AutoLoader::registerClass($className, $file->getPathname());
            }elseif (substr(strtolower ($file->getFilename()), -4) === '.php') {
                $className = substr($file->getFilename(), 0, -4);
                AutoLoader::registerClass($className, $file->getPathname());
            }
        }
    }

    public static function registerClass($className, $fileName) {
        AutoLoader::$classNames[$className] = $fileName;
    }

    public static function loadClass($className) {
        if (isset(AutoLoader::$classNames[$className])) {
            require_once(AutoLoader::$classNames[$className]);
        }
     }

}

spl_autoload_register(array('AutoLoader', 'loadClass'));
?>

简而言之,是的,autoloader被调用用于静态

你可以自己测试一下:

/index.php
该自动加载器确实需要您注册一个目录来填充自动加载器::$classNames,然后才能自动加载正确的类@MarkBaker,我正在这样做,它正在加载目录中的其他类以及包含我的类常量的类。应该可以正常工作。类文件名中是否有拼写错误?检查一下,除了常数之外,你是否可以调用这个类的其他任何东西。谢谢。我想出来了。我正在处理其他人编写的现有代码,并打印出autoloader正在加载的内容,这表明在不同的位置有两个同名的类。一个有我想要的常数,另一个没有。把这屎擦干净。
<?php

    class Init {
        function __construct() {
            spl_autoload_register(array($this, 'loadClass'));
            echo MyThing::BORIS;
        }
        function loadClass($className) {
            $possible_file = 'classes/' . strtolower($className) . '.php';
            echo 'Autoloader called for ' . $className . '<br />';
            if(file_exists($possible_file)) {
                require_once($possible_file);
                return true;
            }
            return false;
        }
    }

    new Init();
<?php

    class MyThing {
        const BORIS = 'Yeltsin';
    }
Autoloader called for MyThing
Yeltsin