MethodImplAttributes 列挙型

定義

メソッド実装の属性のフラグを指定します。Specifies flags for the attributes of a method implementation.

この列挙体には FlagsAttribute 属性があり、そのメンバー値のビットごとの組み合わせが可能になります。

この API は製品インフラストラクチャをサポートします。コードから直接使用するものではありません。

public enum class MethodImplAttributes
public enum MethodImplAttributes
[System.Flags]
[System.Serializable]
public enum MethodImplAttributes
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum MethodImplAttributes
type MethodImplAttributes = 
[<System.Flags>]
[<System.Serializable>]
type MethodImplAttributes = 
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type MethodImplAttributes = 
Public Enum MethodImplAttributes
継承
MethodImplAttributes
属性

フィールド

AggressiveInlining 256

可能な限りメソッドがインライン展開されることを指定します。Specifies that the method should be inlined wherever possible.

AggressiveOptimization 512

可能な限りメソッドを最適化するように指定します。Specifies that the method should be optimized whenever possible.

CodeTypeMask 3

コードの種類に関してフラグを指定します。Specifies flags about code type.

ForwardRef 16

メソッドが定義されないことを指定します。Specifies that the method is not defined.

IL 0

メソッド実装が Microsoft intermediate language (MSIL) であることを指定します。Specifies that the method implementation is in Microsoft intermediate language (MSIL).

InternalCall 4096

内部の呼び出しを指定します。Specifies an internal call.

Managed 0

メソッドがマネージド コードで実装されることを指定します。Specifies that the method is implemented in managed code.

ManagedMask 4

メソッドがマネージド コードとアンマネージド コードのどちらで実装されるかを指定します。Specifies whether the method is implemented in managed or unmanaged code.

MaxMethodImplVal 65535

範囲チェックの値を指定します。Specifies a range check value.

Native 1

メソッド実装がネイティブであることを指定します。Specifies that the method implementation is native.

NoInlining 8

メソッドがインライン化できないことを指定します。Specifies that the method cannot be inlined.

NoOptimization 64

コード生成の問題をデバッグする場合に、メソッドを最適化するために Just-In-Time (JIT) コンパイラまたはネイティブ コードによる生成を使用しないことを指定します (Ngen.exe を参照)。Specifies that the method is not optimized by the just-in-time (JIT) compiler or by native code generation (see Ngen.exe) when debugging possible code generation problems.

OPTIL 2

メソッド実装が Optimized Intermediate Language (OPTIL) であることを指定します。Specifies that the method implementation is in Optimized Intermediate Language (OPTIL).

PreserveSig 128

メソッド シグネチャが宣言どおりにエクスポートされることを指定します。Specifies that the method signature is exported exactly as declared.

Runtime 3

ランタイムによりメソッド実装が提供されることを指定します。Specifies that the method implementation is provided by the runtime.

SecurityMitigations 1024

このメンバーは将来使用するために予約されています。This member is reserved for future use. .NET Framework 4.8 で導入されました。It was introduced in .NET Framework 4.8.

Synchronized 32

本体から、メソッドがシングル スレッドであることを指定します。Specifies that the method is single-threaded through the body. 静的メソッド (Visual Basic ではShared ) は型をロックし、インスタンス メソッドはインスタンスをロックします。Static methods (Shared in Visual Basic) lock on the type, whereas instance methods lock on the instance. C# の lock ステートメントまたは Visual Basic の SyncLock ステートメントも、この目的に使用できます。You can also use the C# lock statement or the Visual Basic SyncLock statement for this purpose.

Unmanaged 4

メソッドがアンマネージ コードで実装されることを指定します。Specifies that the method is implemented in unmanaged code.

注釈

属性は、次のようにビットごとの OR 演算を使用して結合されます。The attributes are combined using the bitwise OR operation as follows:

コード実装マスク:Code implementation masks:

  • CodeTypeMask

  • IL

  • Native

  • OPTIL

  • Runtime

管理対象マスク:Managed masks:

  • ManagedMask

  • Unmanaged

  • Managed

実装情報と相互運用マスク:Implementation information and interop masks:

  • ForwardRef

  • PreserveSig

  • InternalCall

  • Synchronized

  • NoInlining

  • NoOptimization

  • MaxMethodImplVal

  • SecurityMitigations (.NET Framework 4.8 以降で使用できます)。SecurityMitigations (Available starting with .NET Framework 4.8.)

注意

パブリック型では、インスタンスまたは型に対するロックは、パブリック型には Synchronized 推奨されません。これは、独自のコード以外のコードがパブリック型とインスタンスでロックを受け取ることができるためです。Locking on the instance or on the type, as with the Synchronized flag, is not recommended for public types, because code other than your own can take locks on public types and instances. これにより、デッドロックや他の同期の問題が発生する可能性があります。This might cause deadlocks or other synchronization problems.

適用対象

こちらもご覧ください