エディターは名前空間の呼び出しシーケンスを教えてくれます。

醉折花枝作酒筹
リリース: 2023-03-11 20:56:02
オリジナル
1659 人が閲覧しました

前回の記事では、名前空間の内部要素へのアクセスについて学習しましたので、必要に応じて「名前空間の内部要素へのアクセス方法をエディタで紹介します(php版)」も併せてお読みください。今回は名前空間の順序を紹介しますので、必要に応じて参照してください。

まず、小さな例を見てみましょう。

<?php
namespace A;
use B\D, C\E as F;

// 函数调用

foo();      // 首先尝试调用定义在命名空间"A"中的函数foo()
            // 再尝试调用全局函数 "foo"

\foo();     // 调用全局空间函数 "foo" 

my\foo();   // 调用定义在命名空间"A\my"中函数 "foo" 

F();        // 首先尝试调用定义在命名空间"A"中的函数 "F" 
            // 再尝试调用全局函数 "F"

// 类引用

new B();    // 创建命名空间 "A" 中定义的类 "B" 的一个对象
            // 如果未找到,则尝试自动装载类 "A\B"

new D();    // 使用导入规则,创建命名空间 "B" 中定义的类 "D" 的一个对象
            // 如果未找到,则尝试自动装载类 "B\D"

new F();    // 使用导入规则,创建命名空间 "C" 中定义的类 "E" 的一个对象
            // 如果未找到,则尝试自动装载类 "C\E"

new \B();   // 创建定义在全局空间中的类 "B" 的一个对象
            // 如果未发现,则尝试自动装载类 "B"

new \D();   // 创建定义在全局空间中的类 "D" 的一个对象
            // 如果未发现,则尝试自动装载类 "D"

new \F();   // 创建定义在全局空间中的类 "F" 的一个对象
            // 如果未发现,则尝试自动装载类 "F"

// 调用另一个命名空间中的静态方法或命名空间函数

B\foo();    // 调用命名空间 "A\B" 中函数 "foo"

B::foo();   // 调用命名空间 "A" 中定义的类 "B" 的 "foo" 方法
            // 如果未找到类 "A\B" ,则尝试自动装载类 "A\B"

D::foo();   // 使用导入规则,调用命名空间 "B" 中定义的类 "D" 的 "foo" 方法
            // 如果类 "B\D" 未找到,则尝试自动装载类 "B\D"

\B\foo();   // 调用命名空间 "B" 中的函数 "foo" 

\B::foo();  // 调用全局空间中的类 "B" 的 "foo" 方法
            // 如果类 "B" 未找到,则尝试自动装载类 "B"

// 当前命名空间中的静态方法或函数

A\B::foo();   // 调用命名空间 "A\A" 中定义的类 "B" 的 "foo" 方法
              // 如果类 "A\A\B" 未找到,则尝试自动装载类 "A\A\B"

\A\B::foo();  // 调用命名空间 "A" 中定义的类 "B" 的 "foo" 方法
              // 如果类 "A\B" 未找到,则尝试自动装载类 "A\B"
?>
ログイン後にコピー

上記の小さな例を注意深く見てみると、何が観察できるでしょうか?ダンダン、今から答えます。

関数を呼び出すときに、「foo()」とだけ記述すると、名前空間内の関数が最初に呼び出され、次にグローバル関数が呼び出されます。 "\foo()"、これはグローバル関数を呼び出すだけです。

クラスを適用する際に「new B();」と記述すると名前空間に定義されたクラス「B」のオブジェクトが作成されますが、それが見つからない場合は、次に、クラス "A\B" を自動的にロードしてみます。

別の名前空間の静的メソッドまたは名前空間関数を呼び出すときは、「B\foo()」と記述します。これは、名前空間関数 Function "foo( )"; しかし、"B::foo();" と書くと違います。最初に関数 "foo() in the namespace " を呼び出しますが、見つからない場合は、関数を呼び出します。クラス「A\B」を自動ロードするように作られています。

現在の名前空間に静的メソッドまたは関数を記述するときは、「A\B::foo();」と記述します。これは、名前空間を「A The」と呼ぶことを示します。 \A" で定義されたクラス "B" の "foo" メソッドは、クラス "A\A\B" が見つからない場合に自動的にロードします。

それでは、まとめてみましょう。

  • 完全修飾関数、クラス、および定数への呼び出しはコンパイル時に解決されます。たとえば、new\a\B はクラス a\B に解決されます。

  • すべての非修飾名と修飾名 (非完全修飾名) は、現在のインポート ルールに従ってコンパイル時に変換されます。たとえば、ネームスペース A\B\C が C としてインポートされる場合、C\D\e() の呼び出しは A\B\C\D\e() に変換されます。

  • すべての非修飾名と修飾名 (非完全修飾名) は、現在のインポート ルールに従ってコンパイル時に変換されます。たとえば、名前空間 a\B\C が C としてインポートされた場合、C\D\e() の呼び出しは a\B\C\D\e() に変換されます。

  • 修飾されていないクラス名は、現在のインポート ルールに従ってコンパイル時に変換されます (短いインポート名は完全名に置き換えられます)。たとえば、名前空間 a\B\C が C としてインポートされた場合、新しい C() は新しい a\B\C() に変換されます。

  • 名前空間 (例: a\b) 内では、修飾されていない名前への関数呼び出しは実行時に解決されます。たとえば、関数 foo() への呼び出しは次のように解析されます。

    • 現在の名前空間で A\B\foo() という名前の関数を探します

    • グローバル空間で関数 foo() を見つけて呼び出してみます。

  • 名前空間 (a\b など) 内の非修飾名または修飾名クラス (非完全修飾名) への呼び出しは、実行時に解決されます。以下は、new c() および new d\e() を呼び出す解析プロセスです。 new c() の解析:

    • 現在のファイル内で A\B\C を検索します。名前空間の種類。

    • クラス A\B\C を自動的にロードしてみます。

  • 新しい D\E() の解析:

    • クラス名の前に現在の名前空間名を追加します. into: A\B\D\E を入力し、クラスを探します。

    • クラス A\B\D\E を自動ロードしてみます。

  • グローバル名前空間内のグローバル クラスを参照するには、完全修飾名 new \C() を使用する必要があります。

これですべてです。他に知りたいことがある場合は、ここをクリックしてください。 → →phpビデオチュートリアル

以上がエディターは名前空間の呼び出しシーケンスを教えてくれます。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
php
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート