共用方式為


以 AttributeUsageAttribute 標記屬性

更新:2007 年 11 月

型別名稱

MarkAttributesWithAttributeUsage

CheckId

CA1018

分類

Microsoft.Design

中斷變更

中斷

原因

System.AttributeUsageAttribute 屬性未出現於自訂屬性中。

規則描述

定義自訂屬性時,請使用 AttributeUsageAttribute 標示它,以指出可以在原始程式碼的哪個位置套用自訂屬性。屬性的意義和預期的用法將決定它在程式碼中的有效位置。例如,如果您正在定義一個屬性,以識別負責維護和加強程式庫中每個型別的人員,且此責任一律是在型別層級中進行指派,則編譯器 (Compiler) 應該允許類別、列舉型別和介面上的屬性,但不應該允許方法、事件或屬性 (Property) 上的屬性 (Attribute)。組織原則和程序將指出是否應該允許組件 (Assembly) 上的屬性。

System.AttributeTargets 列舉型別會定義您可以指定給自訂屬性的目標。如果略過 AttributeUsageAttribute,您的自訂屬性對所有目標都會有效,如 All 所定義。

如何修正違規

若要修正此規則的違規情形,請使用 AttributeUsageAttribute 指定屬性的目標。請參閱下列範例。

隱藏警告的時機

您應該修正此規則的違規情形,而不是排除訊息。即使屬性繼承 AttributeUsageAttribute,該屬性也應該出現以簡化程式碼維護。

範例

下列範例會定義兩個屬性。BadCodeMaintainerAttribute 會不正確地略過 AttributeUsageAttribute 陳述式,而 GoodCodeMaintainerAttribute 則會正確地實作上述的屬性。請注意,必須定義屬性引數的存取子設計規則需要屬性 DeveloperName,且包括這個屬性後才比較完整。

Imports System

Namespace DesignLibrary

' Violates rule: MarkAttributesWithAttributeUsage.
NotInheritable Public Class BadCodeMaintainerAttribute
    Inherits Attribute
    Private developer As String

    Public Sub New(developerName As String)
        developer = developerName
    End Sub 'New

    Public ReadOnly Property DeveloperName() As String
        Get
            Return developer
        End Get
    End Property
End Class 

' Satisfies rule: Attributes specify AttributeUsage.
' The attribute is valid for type-level targets.
<AttributeUsage(AttributeTargets.Class Or AttributeTargets.Enum Or _ 
   AttributeTargets.Interface Or AttributeTargets.Delegate)> _
NotInheritable Public Class GoodCodeMaintainerAttribute
    Inherits Attribute
    Private developer As String

    Public Sub New(developerName As String)
        developer = developerName
    End Sub 'New

    Public ReadOnly Property DeveloperName() As String
        Get
            Return developer
        End Get
    End Property
End Class 

End Namespace
using System;

namespace DesignLibrary
{
// Violates rule: MarkAttributesWithAttributeUsage.

   public sealed class BadCodeMaintainerAttribute :Attribute 
   {
      string developer;

      public BadCodeMaintainerAttribute(string developerName)
      {
         developer = developerName;
      }
      public string DeveloperName
      {
         get 
         {
            return developer;
         }
      }
   }
// Satisfies rule: Attributes specify AttributeUsage.

   // The attribute is valid for type-level targets.
   [AttributeUsage(AttributeTargets.Class | AttributeTargets.Enum | AttributeTargets.Interface | AttributeTargets.Delegate)]
   public sealed class GoodCodeMaintainerAttribute :Attribute 
   {
      string developer;

      public GoodCodeMaintainerAttribute(string developerName)
      {
         developer = developerName;
      }
      public string DeveloperName
      {
         get 
         {
            return developer;
         }
      }
   }
}

相關規則

必須定義屬性引數的存取子

避免使用非密封屬性

請參閱

參考

屬性用法方針

System.AttributeTargets