MethodImplAttributes Enum
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Specifies flags for the attributes of a method implementation.
This enumeration supports a bitwise combination of its member values.
This API supports the product infrastructure and is not intended to be used directly from your code.
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
- Inheritance
- Attributes
Fields
Name | Value | Description |
---|---|---|
IL | 0 | Specifies that the method implementation is in Microsoft intermediate language (MSIL). |
Managed | 0 | Specifies that the method is implemented in managed code. |
Native | 1 | Specifies that the method implementation is native. |
OPTIL | 2 | Specifies that the method implementation is in Optimized Intermediate Language (OPTIL). |
CodeTypeMask | 3 | Specifies flags about code type. |
Runtime | 3 | Specifies that the method implementation is provided by the runtime. |
ManagedMask | 4 | Specifies whether the method is implemented in managed or unmanaged code. |
Unmanaged | 4 | Specifies that the method is implemented in unmanaged code. |
NoInlining | 8 | Specifies that the method cannot be inlined. |
ForwardRef | 16 | Specifies that the method is not defined. |
Synchronized | 32 | Specifies that the method is single-threaded through the body. Static methods ( |
NoOptimization | 64 | 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. |
PreserveSig | 128 | Specifies that the method signature is exported exactly as declared. |
AggressiveInlining | 256 | Specifies that the method should be inlined wherever possible. |
AggressiveOptimization | 512 | Specifies that the method should be optimized whenever possible. |
SecurityMitigations | 1024 | This member is reserved for future use. It was introduced in .NET Framework 4.8. |
InternalCall | 4096 | Specifies an internal call. |
MaxMethodImplVal | 65535 | Specifies a range check value. |
Remarks
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
(Available starting with .NET Framework 4.8.)
Note
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.