IsExplicitlyDereferenced クラス
アセンブリ: mscorlib (mscorlib.dll 内)


C++ では、マネージ ポインタとマネージ参照はポインタとしてメタデータに出力されます。メタデータ内の 2 つの型を区別するため、Microsoft C++ コンパイラはこの修飾子をマネージ ポインタに適用します。修飾子はマネージ参照型には出力されません。メタデータ スコープからメソッドをインポートする場合、コンパイラは正しい呼び出し構文を知る必要があります。IsExplicitlyDereferenced クラスおよびそのパートナーである IsImplicitlyDereferenced クラスは、参照パラメータとポインタ パラメータを明確に区別します。
既定の動作が適切でない場合、コンパイラはメタデータ内のカスタム修飾子を出力して、Just-In-Time (JIT) コンパイラによる値の処理方法を変更します。JIT コンパイラは、カスタム修飾子を見つけると、その修飾子の指定に従って値を処理します。コンパイラは、メソッド、パラメータ、および戻り値に対してカスタム修飾子を適用します。JIT コンパイラは、オプションの修飾子は無視できますが、必須の修飾子については応答する必要があります。

リフレクションを使用して、IsExplicitlyDereferenced オブジェクトをアセンブリに出力する方法を次の例に示します。
#using <mscorlib.dll> using namespace System; using namespace System::Reflection; using namespace System::Reflection::Emit; using namespace System::Runtime::CompilerServices; using namespace System::Threading; ref class CodeEmitter { private: AssemblyBuilder^ asmBuilder; String^ asmName; ModuleBuilder^ modBuilder; void prepareAssembly(String^ name){ // Check the input. if(!name){ throw gcnew ArgumentNullException("AssemblyName"); } asmName = name; // Create an AssemblyName object and set the name. AssemblyName^ asmName = gcnew AssemblyName(); asmName->Name = name; // Use the AppDomain class to create an AssemblyBuilder instance. AppDomain^ currentDomain = Thread::GetDomain(); asmBuilder = currentDomain->DefineDynamicAssembly(asmName,AssemblyBuilderAccess::RunAndSave); // Create a dynamic module. modBuilder = asmBuilder->DefineDynamicModule(name); } public: // Constructor. CodeEmitter(String ^ AssemblyName){ prepareAssembly(AssemblyName); } // Create a new type. TypeBuilder^ CreateType(String^ name){ // Check the input. if(!name){ throw gcnew ArgumentNullException("AssemblyName"); } return modBuilder->DefineType( name ); } // Write the assembly. void WriteAssembly(MethodBuilder^ entryPoint){ // Check the input. if(!entryPoint){ throw gcnew ArgumentNullException("entryPoint"); } asmBuilder->SetEntryPoint( entryPoint ); asmBuilder->Save( asmName ); } }; void main() { // Create a CodeEmitter to handle assembly creation. CodeEmitter ^ e = gcnew CodeEmitter("program.exe"); // Create a new type. TypeBuilder^ mainClass = e->CreateType("MainClass"); // Create a new method. MethodBuilder^ mBuilder = mainClass->DefineMethod("mainMethod", MethodAttributes::Static); // Create an ILGenerator and emit IL for // a simple "Hello World." program. ILGenerator^ ilGen = mBuilder->GetILGenerator(); ilGen->Emit(OpCodes::Ldstr, "Hello World"); array<Type^>^mType = {String::typeid}; MethodInfo^ writeMI = Console::typeid->GetMethod( "WriteLine", mType ); ilGen->EmitCall(OpCodes::Call, writeMI, nullptr ); ilGen->Emit( OpCodes::Ret ); ///////////////////////////////////////////////// ///////////////////////////////////////////////// // Apply a required custom modifier // to a field. ///////////////////////////////////////////////// ///////////////////////////////////////////////// array<Type^>^fType = {IsExplicitlyDereferenced::typeid}; mainClass->DefineField("modifiedInteger", Type::GetType("System.IntPtr"), fType, nullptr, FieldAttributes::Private); // Create the type. mainClass->CreateType(); // Write the assembly using a reference to // the entry point. e->WriteAssembly(mBuilder); Console::WriteLine(L"Assembly created."); }

System.Runtime.CompilerServices.IsExplicitlyDereferenced


Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


IsExplicitlyDereferenced メソッド

名前 | 説明 | |
---|---|---|
![]() | Equals | オーバーロードされます。 2 つの Object インスタンスが等しいかどうかを判断します。 ( Object から継承されます。) |
![]() | GetHashCode | 特定の型のハッシュ関数として機能します。GetHashCode は、ハッシュ アルゴリズムや、ハッシュ テーブルのようなデータ構造での使用に適しています。 ( Object から継承されます。) |
![]() | GetType | 現在のインスタンスの Type を取得します。 ( Object から継承されます。) |
![]() | ReferenceEquals | 指定した複数の Object インスタンスが同一かどうかを判断します。 ( Object から継承されます。) |
![]() | ToString | 現在の Object を表す String を返します。 ( Object から継承されます。) |

IsExplicitlyDereferenced メンバ
マネージ ポインタがメソッド シグネチャ内のポインタ パラメータを表すことを示します。このクラスは継承できません。
IsExplicitlyDereferenced データ型で公開されるメンバを以下の表に示します。

名前 | 説明 | |
---|---|---|
![]() | Equals | オーバーロードされます。 2 つの Object インスタンスが等しいかどうかを判断します。 (Object から継承されます。) |
![]() | GetHashCode | 特定の型のハッシュ関数として機能します。GetHashCode は、ハッシュ アルゴリズムや、ハッシュ テーブルのようなデータ構造での使用に適しています。 (Object から継承されます。) |
![]() | GetType | 現在のインスタンスの Type を取得します。 (Object から継承されます。) |
![]() | ReferenceEquals | 指定した複数の Object インスタンスが同一かどうかを判断します。 (Object から継承されます。) |
![]() | ToString | 現在の Object を表す String を返します。 (Object から継承されます。) |

Weblioに収録されているすべての辞書からIsExplicitlyDereferencedを検索する場合は、下記のリンクをクリックしてください。

- IsExplicitlyDereferencedのページへのリンク