/// <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标记此属性是正确的做法。

08-06 07:02