Heim > Artikel > Backend-Entwicklung > Problem beim Laden des PHP-Namespace
Angenommen, die aktuelle Verzeichnisstruktur sieht folgendermaßen aus:
Der Code in A.php lautet:
Namespace A;
Klasse A{
öffentliche Funktion __construct()
{
echo 'AAAAAAAAAAAA';
}
}
Der Code in B.php lautet:
namespace B;
use AA;
new A();
?>
Fehler: Schwerwiegender Fehler: Klasse „AA“ nicht gefunden in. . .
Ich war immer verwirrt über die Namespace-Benennungsregeln von PHP:
Wird PHP diese Klasse automatisch basierend auf dem Namen des Namespace laden?
Auch wenn ein Namespace verwendet wird und eine Datei eine Klasse in einer anderen Datei aufruft, muss sie „require“, „include“ usw. verwenden, um die andere Klassendatei in die aktuelle Datei zu laden, bevor sie instanziiert und verwendet werden kann
Wenn Punkt 2 oben JA lautet, sollten Sie Autoload oder andere Methoden zum Laden verwenden? Stimmt es, dass der sogenannte Namespace nur ein Name zur Unterscheidung von Klassen ist und nicht die Funktion hat, Klassen automatisch zu laden?
Angenommen, die aktuelle Verzeichnisstruktur sieht folgendermaßen aus:
Der Code in A.php lautet:
Namespace A;
Klasse A{
öffentliche Funktion __construct()
{
echo 'AAAAAAAAAAAA';
}
}
Der Code in B.php lautet:
namespace B;
use AA;
new A();
?>
Fehler: Schwerwiegender Fehler: Klasse „AA“ nicht gefunden in. . .
Ich war immer verwirrt über die Namespace-Benennungsregeln von PHP:
Wird PHP diese Klasse automatisch basierend auf dem Namen des Namespace laden?
Auch wenn ein Namespace verwendet wird und eine Datei eine Klasse in einer anderen Datei aufruft, muss sie „require“, „include“ usw. verwenden, um die andere Klassendatei in die aktuelle Datei zu laden, bevor sie instanziiert und verwendet werden kann
Wenn Punkt 2 oben JA lautet, sollten Sie Autoload oder andere Methoden zum Laden verwenden? Stimmt es, dass der sogenannte Namespace nur ein Name zur Unterscheidung von Klassen ist und nicht die Funktion hat, Klassen automatisch zu laden?
Zunächst müssen Sie sich darüber im Klaren sein, was der Namespace tut. Der Namespace ist, wie der Name schon sagt, der Name des Bereichs, in dem Sie sich selbst deklarieren (classestool: entspricht der Ankündigung, dass ich mich im Toolbereich befinde). Mit anderen Worten: Der Namespace, den Sie mithilfe von use eingeführt haben, ist letztlich nur ein „Standortname“ oder require muss den eigentlichen Körper durch include oder require einführen, es ist unmöglich, sich von diesen beiden zu lösen.
Das __autoload und das spl_autoload_register, die wir sehen, gehören zur magischen Einführungsmethode von PHP (tatsächlich ähnelt dieses Konzept der Umkehrung der Kontrolle im objektorientierten (persönlichen Verständnis)), der magischen Einführung - in Laienbegriffen ausgedrückt Erstellen Sie eine Zauberbox. Diese Zauberbox ist dafür verantwortlich, Ihnen bei der Bewältigung der mühsamen Arbeit des Einschließens und Anforderns zu helfen. Wenn Sie das automatische Laden über den Namespace implementieren möchten, müssen Sie die Regeln befolgen: psr-0 automatische Ladespezifikation. Wenn der Standortname gemäß den Regeln deklariert wird, ist der „Standortname“ kann durch Verwendung eingeführt werden Es wird von der Magic Box analysiert. Suchen Sie nach dem Parsen des Standortnamens nach dem Bild und importieren Sie dann die entsprechende Datei über include oder require.
Zusammenfassend hier drei Punkte:
use führt nur den Raumnamen ein, nicht den tatsächlichen Körper
php muss bei der Einführung von PHP-Dateien „require“ und „include“ verwenden;
spl_autoload_register()
verwenden, um Klassendateien require_once
include_onece
zu laden
<code>自动加载: 类库映射 PSR-4自动加载检测 PSR-0自动加载检测 </code>
2.在TP5,可以用use 关键字即可, 不需要做require这样繁琐的操作了
3.已经该用spl_autoload_register了替代autoload, composer的出现不就是为了解决这种加载问题么?所以一定要设置命名空间,命名空间不具有自动加载类的作用,他是为了避免命名冲突和可视化类的路径和真正的懒加载等。
使用spl_autoload_register注册了自动装载函数才能使用use,demo:
<code><?php class Autoload { /** * 类映射 * @var array */ // private static $_classMap = []; public function __construct() { # code... } public static function init() { spl_autoload_register('Autoload::autoload'); } public static function autoload($class_name='') { // if (self::$_classMap[$class_name]) { // require(self::$_classMap[$class_name]); // } require(str_replace('\\', '/', $class_name).'.php'); } } /* register autoload funxtion|注册自动装载函数 */ require('./Autoload.php'); Autoload::init();</code>
pho不会自动加载类。spl_autoload
的加载是从include配置中找对应的 类名.inc
或者 类名.php
来加载。(具体查看 php文档)
ThinkPHP和Laravel以及Composer之类的框架程序,都是通过spl_autoload_resigster
来实现按照一定功能加载类。
命名空间设置的初衷是为了区分不同区的同名类,不一定是按照文件夹来命名,命名空间相当于对类进行分区,比如,你有个类叫 Router
我也有个类叫 Router
,类名重复了,这时命名空间就可以起作用了。
我的回答是是,ThinkPHP的原理是通过 命名空间 来解析成 路径 ,再注册了autoload来加载, 如 abc,会在指定目录找a/bc.class.php (.class.php是tp指定的加载后缀,指定目录通常是library ),Zend 框架是通过 _ 来分割路径,如 a_b_c 类。会变成 /a/b/c.php来在指定目录找。
去了解下php面向对象设计模式 他们说的就是这些