MethodImplOptions Enum

Definition

Specifies constants that define the details of how a method is implemented.

This enumeration supports a bitwise combination of its member values.

public enum class MethodImplOptions
[System.Flags]
public enum MethodImplOptions
[System.Flags]
[System.Serializable]
public enum MethodImplOptions
[System.Flags]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public enum MethodImplOptions
[<System.Flags>]
type MethodImplOptions = 
[<System.Flags>]
[<System.Serializable>]
type MethodImplOptions = 
[<System.Flags>]
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type MethodImplOptions = 
Public Enum MethodImplOptions
Inheritance
MethodImplOptions
Attributes

Fields

AggressiveInlining 256

The method should be inlined if possible.

AggressiveOptimization 512

The method contains code that should always be optimized by the just-in-time (JIT) compiler.

Use this attribute if running an unoptimized version of the method has undesirable effects, for instance causing too much overhead or extra memory allocation.

Methods with this attribute may not have optimal code generation. They bypass the first tier of Tiered Compilation and therefore can't benefit from optimizations that rely on tiering, for example, Dynamic PGO or optimizations based on initialized classes.

ForwardRef 16

The method is declared, but its implementation is provided elsewhere.

InternalCall 4096

The call is internal, that is, it calls a method that's implemented within the common language runtime.

NoInlining 8

The method cannot be inlined. Inlining is an optimization by which a method call is replaced with the method body.

NoOptimization 64

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

The method signature is exported exactly as declared.

SecurityMitigations 1024

This member is reserved for future use. It was introduced in .NET Framework 4.8.

Synchronized 32

The method can be executed by only one thread at a time. Static methods lock on the type, whereas instance methods lock on the instance. Only one thread can execute in any of the instance functions, and only one thread can execute in any of a class's static functions.

Unmanaged 4

The method is implemented in unmanaged code.

Remarks

This enumeration is used with the MethodImplAttribute attribute.

You can specify multiple MethodImplOptions values by using the bitwise OR operator.

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.

Applies to