相互参照する型ヒントを持つクラスを定義すると、循環依存関係エラーが発生し、型ヒントが無効になることがあります。このエラーは多くの場合、NameError として現れ、現在の名前空間内でクラス名が見つからないことを示します。
次のコード スニペットを考えてみましょう:
<code class="python">class Server: def register_client(self, client: Client) pass class Client: def __init__(self, server: Server): server.register_client(self)</code>
この例では、Server クラスは register_client メソッドへの引数として Client オブジェクトを予期しますが、Client クラスはコンストラクターで Server インスタンスを予期します。ただし、この循環依存関係により、コードは NameError で失敗します: name 'Client' が定義されていません。
この問題に対する 1 つの解決策は、前方参照を使用することです。 Client をタイプ ヒント内の文字列として宣言すると、インタプリタは後で依存関係を解決できます。
<code class="python">class Server: def register_client(self, client: 'Client') pass</code>
代わりに、Python 3.7 ではアノテーションの延期された評価が導入されました。 future import from __future__ import アノテーションをモジュールの先頭に追加することにより、アノテーションは抽象構文ツリーの文字列表現として保存されます。これらの注釈は、後で testing.get_type_hints() を使用して解決できます。
<code class="python">from __future__ import annotations class Server: def register_client(self, client: Client) pass</code>
以上が型ヒントの循環依存関係を効果的に型強制するためにどのように解決できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。