/// <summary>
/// Specifies flags for the attributes of a method implementation.
/// </summary>
[ComVisible(true)]
[__DynamicallyInvokable]
[Serializable]
public enum MethodImplAttributes
{
[__DynamicallyInvokable] IL = 0,
[__DynamicallyInvokable] Managed = 0,
[__DynamicallyInvokable] Native = 1,
[__DynamicallyInvokable] OPTIL = 2,
[__DynamicallyInvokable] CodeTypeMask = 3,
[__DynamicallyInvokable] Runtime = 3,
[__DynamicallyInvokable] ManagedMask = 4,
[__DynamicallyInvokable] Unmanaged = 4,
[__DynamicallyInvokable] NoInlining = 8,
[__DynamicallyInvokable] ForwardRef = 16,
[__DynamicallyInvokable] Synchronized = 32,
[__DynamicallyInvokable] NoOptimization = 64,
[__DynamicallyInvokable] PreserveSig = 128,
[ComVisible(false), __DynamicallyInvokable] AggressiveInlining = 256,
[__DynamicallyInvokable] InternalCall = 4096,
MaxMethodImplVal = 65535,
}
为什么此枚举未用FlagsAttribute标记?在您可以在MSDN上找到的所有示例中,它都像位字段一样使用,并且MSDN上的属性的大多数准则都与此定义匹配。
MethodBuilder.SetImplementationFlags()甚至暗示它的使用类似于MSDN示例代码之外的带有[Flags]标记的枚举。
最佳答案
您可以始终对这些枚举使用位操作,即使它们未标记为FlagsAttribute
。实际上,FlagsAttribute
仅用于.ToString
方法,使输出字符串更漂亮。
enum DataFlag
{
Private = 1,
Important = 2,
Persistant = 4
}
var flag = DataFlag.Private | DataFlag.Persistant;
var test = flag.HasFlag(DataFlag.Private); //True with/without FlagAttribute
var stringResult = flag.ToString(); // with FlagAttribute: Private, Persistant
// without : 5
顺便说一句,此枚举具有
MethodImplAttributes.IL = 0
,即使您具有.ToString
,该枚举也不会出现在FlagsAttribute
输出中,并且一些字段具有相同的值,这可能会导致意外的行为字符串结果。一般来说,不使用FlagsAttribute
标记此属性是正确的做法。