検索
ホームページ開発ツールcomposerComposer自動ロード機構の詳細説明

composer の次のチュートリアル コラムでは、composer の自動読み込みメカニズムを浅いところから深いところまで紹介します。

Composer自動ロード機構の詳細説明

#まえがき

作曲家にとっては自動的に唯一の記憶だから読み込みメカニズムに残っているのは、「spl_auto???」と「名前空間に基づいたファイル パスの導出」です。 。 。まだ不完全です。 。

ネット上で詳細な説明を集めたかったのですが、「簡単なものから深いものまで」という私の意見に当てはまる記事が見つかりませんでした。

それで、私はこのメモを持っています。

次のナレッジ ポイントは近日公開予定です:
1. spl_autoload_register について学ぶ

2. Composer アップデートのストーリー

3. Composer の自動読み込みを追跡する

テキスト

1. spl_autoload_register について学びます

まず公式の php マニュアルを確認してください:

(面倒な方は赤い部分だけ見てください)
Composer自動ロード機構の詳細説明そうですか?無知のようですね?
現地語で翻訳しましょう:


新しいクラスを作成する場合は、最初にクラス ファイルを要求するか含める必要があります。ロードされていない場合は、エラーが報告されます。これは問題を引き起こします。この場合、ファイルのヘッダーは要件とインクルードでいっぱいですが、これは明らかにプログラマーの「怠け者」のニーズに沿っていません。

クラス ファイルを必要としたり、クラス ファイルを含めたりせずに新しいクラスを通常に作成するために、自動ロード メカニズムが登場しました。 spl_autoload_register 関数は、これを行うために特別に設計されています。

#スクリーンショットから、この関数には 3 つのパラメータがあることがわかります。

#パラメータ

詳細な説明autoload_functionここに ***「関数」*** の名前、文字列または配列を入力します。この関数の関数new を必要とするファイルをロードすることです。new を使用するときにエラーが報告されるのを避けるために、できる限り新しい Require または include が必要です。簡単に言うと、***ファイルを自動的にロードする関数***をカプセル化する必要があります***throw自動ロードされる関数が登録できない場合、 Exception をスローする #

来一波代码,印象深刻一些:

//文件 testClass.php ,即将new的类
class TestClass{
    public function __construct() {
        echo '你已经成功new了我了';
    }
}

//文件autoloadDemo.php文件
spl_autoload_register('autoLoad_function', true, true);
function autoLoad_function($class_name){
    echo "所有的require或者include文件工作都交给我吧!\r\n";
    $class_filename = "./{$class_name}.php";
    echo "我来加载{$class_filename}文件\r\n";
    require_once("./{$class_name}.php");
}
$obj_demo = new TestClass();

输出:

所有的require或者include文件工作都交给我吧!
我来加载testClass.php文件
你已经成功new了我了

明白了这个加载的原理,看下文就顺利多了。

2.composer update发生的故事

将自动加载之前,必须要先说一下composer update,这里头承载了自动加载的前提。

composer项目都包含一个composer.json的配置文件。
Composer自動ロード機構の詳細説明
这里头有一个关键的字段"autoload",包含psr-4和files两个字段。

psr-4:说明是基于psr-4规范的类库,都支持自动加载,只要在后面的对象中以**“命名空间:路径”**的方式写入自己的类库信息即可。
files:这就就更直接了,写入路径就自动加载。

按照以上配置每回composer update之后呢,都会更新一个很重要的文件:./vender/composer/autoload_psr4.php。
Composer自動ロード機構の詳細説明

这个文件只做了一件事情:把命名空间和文件路径对应起来,这样后续自动加载就有映射根据了。

3.追踪一下composer的自动加载

composer的故事从唯一的一个require说起:

require '../vendor/autoload.php'

这个脚本执行了一个函数:

ComposerAutoloaderInitd9b31141b114fcbee3cf55d0e97b7f87::getLoader()

继续跟getloader函数做了什么?

public static function getLoader() {
   if (null !== self::$loader) {
        return self::$loader;
    }

    spl_autoload_register(array('ComposerAutoloaderInitd9b31141b114fcbee3cf55d0e97b7f87', 'loadClassLoader'), true, true);
    self::$loader = $loader = new \Composer\Autoload\ClassLoader();
    spl_autoload_unregister(array('ComposerAutoloaderInitd9b31141b114fcbee3cf55d0e97b7f87', 'loadClassLoader'));

    $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
    if ($useStaticLoader) {
        require_once __DIR__ . '/autoload_static.php';

        call_user_func(\Composer\Autoload\ComposerStaticInitd9b31141b114fcbee3cf55d0e97b7f87::getInitializer($loader));
    } else {
        $map = require __DIR__ . '/autoload_namespaces.php';
        foreach ($map as $namespace => $path) {
            $loader->set($namespace, $path);
        }

        $map = require __DIR__ . '/autoload_psr4.php';
        foreach ($map as $namespace => $path) {
            $loader->setPsr4($namespace, $path);
        }

        $classMap = require __DIR__ . '/autoload_classmap.php';
        if ($classMap) {
            $loader->addClassMap($classMap);
        }
    }

    $loader->register(true);

    if ($useStaticLoader) {
        $includeFiles = Composer\Autoload\ComposerStaticInitd9b31141b114fcbee3cf55d0e97b7f87::$files;
    } else {
        $includeFiles = require __DIR__ . '/autoload_files.php';
    }
    foreach ($includeFiles as $fileIdentifier => $file) {
        composerRequired9b31141b114fcbee3cf55d0e97b7f87($fileIdentifier, $file);
    }

    return $loader;
}

这个函数主要做了两件事情:
1.将各种存有命名空间和文件映射关系的文件autoload_xxx.php加载了进来,并作了一些处理(比如:setPsr4将相关映射加载了进去,这个留意下,下文会有呼应。)。
2.注册了函数register

继续跟踪register做了什么:

public function register($prepend = false) {
   spl_autoload_register(array($this, 'loadClass'), true, $prepend);
}

原来调用了spl_autoload_register函数,当类没加载的时候使用loadClass来加载类。(这个前文讲的很清楚了,应该很熟了)

继续跟踪loadClass实现:

public function loadClass($class) {
	if ($file = $this->findFile($class)) {
		includeFile($file);
		return true;
	}
}

大概可以看出,是做了文件的include。
继续跟踪下是怎么查找文件的,看findFile函数:

public function findFile($class) {
    // class map lookup
    if (isset($this->classMap[$class])) {
        return $this->classMap[$class];
    }
    if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
        return false;
    }
    if (null !== $this->apcuPrefix) {
        $file = apcu_fetch($this->apcuPrefix.$class, $hit);
        if ($hit) {
            return $file;
        }
    }

    $file = $this->findFileWithExtension($class, '.php');

    // Search for Hack files if we are running on HHVM
    if (false === $file && defined('HHVM_VERSION')) {
        $file = $this->findFileWithExtension($class, '.hh');
    }

    if (null !== $this->apcuPrefix) {
        apcu_add($this->apcuPrefix.$class, $file);
    }

    if (false === $file) {
        // Remember that this class does not exist.
        $this->missingClasses[$class] = true;
    }

    return $file;
}

这个函数做了一件事:就是寻找类从上文的autoload_xxx.php初始化的数据中来寻找映射的文件路径。
其中这个函数findFileWithExtension,适用于寻找psr-4规范的文件的映射信息的。

继续跟踪findFileWithExtension:

private function findFileWithExtension($class, $ext) {
    // PSR-4 lookup
    $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;

    $first = $class[0];
    if (isset($this->prefixLengthsPsr4[$first])) {
        $subPath = $class;
        while (false !== $lastPos = strrpos($subPath, '\\')) {
            $subPath = substr($subPath, 0, $lastPos);
            $search = $subPath.'\\';
            if (isset($this->prefixDirsPsr4[$search])) {
                $pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
                foreach ($this->prefixDirsPsr4[$search] as $dir) {
                    if (file_exists($file = $dir . $pathEnd)) {
                        return $file;
                    }
                }
            }
        }
    }

    // PSR-4 fallback dirs
    foreach ($this->fallbackDirsPsr4 as $dir) {
        if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
            return $file;
        }
    }

    // PSR-0 lookup
    if (false !== $pos = strrpos($class, '\\')) {
        // namespaced class name
        $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
            . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
    } else {
        // PEAR-like class name
        $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
    }

    if (isset($this->prefixesPsr0[$first])) {
        foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
            if (0 === strpos($class, $prefix)) {
                foreach ($dirs as $dir) {
                    if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
                        return $file;
                    }
                }
            }
        }
    }

    // PSR-0 fallback dirs
    foreach ($this->fallbackDirsPsr0 as $dir) {
        if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
            return $file;
        }
    }

    // PSR-0 include paths.
    if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
        return $file;
    }

    return false;
}

这个函数做了件事:将命名空间\类这样的类名,转换成目录名/类名.php这样的路径,再从前文setPsr4设置的映射信息中寻找映射信息,然后完成返回路径。

至此composer的自动加载机制结束。

#prepend 関数を関数キューの先頭に追加するかどうか。true の場合は先頭、それ以外の場合は末尾

以上がComposer自動ロード機構の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はcsdnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
作曲家になる:トレーニング、教育、経験作曲家になる:トレーニング、教育、経験Apr 28, 2025 am 12:11 AM

作曲家になるには、音楽理論、調和、対抗点を習得し、楽器のトーンとパフォーマンスのスキルに精通する必要があります。作曲家は音楽を通して感情と物語を表現し、創造的なプロセスには、作品へのアイデアの構築と改善が含まれます。

作曲家の識別:重要な要素作曲家の識別:重要な要素Apr 27, 2025 am 12:27 AM

作曲家を識別するための重要な手順には、次のものがあります。1)ベートーベンのドラマやパワーなどの作曲家の文体的な特徴の分析。 2)バッハのバロック様式などの作曲家の歴史的背景と文化的影響を理解する。 3)単一の要素のみに依存することによって引き起こされる誤判断を避けるために、作業のメロディー、調和、リズム、構造を包括的に分析する。

作曲家:PHP開発におけるAIの未来作曲家:PHP開発におけるAIの未来Apr 26, 2025 am 12:10 AM

Composer'sfutureinphpdevelopments withaiincludes:1)ai-enhanced dependencymanagementforsuggestinglibraries、2)ai-drivencodegeneration forialeoredboilerplate、および3)

作曲家のスキルと資質:概要作曲家のスキルと資質:概要Apr 25, 2025 am 12:03 AM

成功した作曲家になるには、音楽理論、楽器のパフォーマンス、サウンドデザインなどのスキルや、キャプチャと絶え間ない仕事の修正への鋭いインスピレーションが必要です。作曲家はこれらのスキルと特性を使用して、感情と思考を音楽作品に変え、リスナーと共鳴します。

作曲家の資格:習熟度の評価作曲家の資格:習熟度の評価Apr 24, 2025 am 12:15 AM

作曲家の習熟度は、次の4つの側面で評価できます。1)パッケージ、依存関係、バージョン制御などの基本概念を理解する。 2)Composer.jsonの解析、依存関係の解決、パッケージのダウンロード、Autoloadファイルの生成を含むマスターコア関数。 3)ComposerInstall、更新、要求、およびダンプオートロードなど、基本的および高度なコマンドを使用するのに習熟しています。 4)Composer.Lockファイルの使用、AutoLOAD構成の最適化、定期的にキャッシュのクリーニングなどのベストプラクティスを適用します。

作曲家:自動タスクのAIを活用します作曲家:自動タスクのAIを活用しますApr 23, 2025 am 12:03 AM

Composerを使用してAIを組み合わせて自動タスクを実現します。 1。Composerは、構成ファイルを介して依存関係を管理し、AIはバージョンの選択を最適化できます。 2。実際のアプリケーションでは、AIを使用して、依存関係の管理、テスト、展開を自動化できます。 3.パフォーマンスの最適化には、依存関係の負荷とキャッシュ戦略が含まれます。 4.バージョンの競合やAIの誤判断などの問題に注意してください。これらの方法により、AIは仕事の効率と知性を改善できます。

AIの作曲家:コード提案と洞察AIの作曲家:コード提案と洞察Apr 22, 2025 am 12:05 AM

ComposerWithaiは、AIを使用してプログラミングエクスペリエンスを向上させるツールです。 1)コード構造、構文、パターンを分析することにより、リアルタイムの提案とバグ修正を提供します。 2)高度な機能には、コードのリファクタリング、パフォーマンスの最適化、セキュリティチェックが含まれます。 3)使用する場合、構成を調整し、フィードバックを提供し、他のツールを組み合わせて一般的な問題を解決できます。

作曲家:PHP依存関係マネージャーの紹介作曲家:PHP依存関係マネージャーの紹介Apr 21, 2025 am 12:02 AM

Composerは、PHPの依存関係管理ツールであり、プロジェクトに必要なライブラリとパッケージを管理するために使用されます。 1)composer.jsonファイルを介して依存関係を定義します。2)コマンドラインツールを使用してインストールと更新、3)依存関係管理プロセスを自動化し、開発効率を向上させ、4)依存関係を動的に追加するなどの高度な機能をサポートします。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、