C #-특성

attribute프로그램에서 클래스, 메서드, 구조, 열거 자, 어셈블리 등과 같은 다양한 요소의 동작에 대한 정보를 런타임에 전달하는 데 사용되는 선언적 태그입니다. 특성을 사용하여 프로그램에 선언적 정보를 추가 할 수 있습니다. 선언적 태그는 사용되는 요소 위에 배치 된 사각형 ([]) 대괄호로 표시됩니다.

속성은 컴파일러 명령과 같은 메타 데이터와 주석, 설명, 메서드 및 클래스와 같은 기타 정보를 프로그램에 추가하는 데 사용됩니다. .Net Framework는 사전 정의 된 속성과 사용자 정의 빌드 속성의 두 가지 유형의 속성을 제공 합니다.

속성 지정

속성을 지정하는 구문은 다음과 같습니다.

[attribute(positional_parameters, name_parameter = value, ...)]
element

속성의 이름과 해당 값은 속성이 적용되는 요소 앞의 대괄호 안에 지정됩니다. 위치 매개 변수는 필수 정보를 지정하고 이름 매개 변수는 선택적 정보를 지정합니다.

미리 정의 된 속성

.Net Framework는 세 가지 미리 정의 된 속성을 제공합니다.

  • AttributeUsage
  • Conditional
  • Obsolete

AttributeUsage

미리 정의 된 속성 AttributeUsage사용자 정의 속성 클래스를 사용할 수있는 방법을 설명합니다. 속성을 적용 할 수있는 항목의 유형을 지정합니다.

이 속성을 지정하는 구문은 다음과 같습니다.

[AttributeUsage (
   validon,
   AllowMultiple = allowmultiple,
   Inherited = inherited
)]

어디,

  • validon 매개 변수는 속성을 배치 할 수있는 언어 요소를 지정합니다. 열거 자 AttributeTargets 값의 조합입니다 . 기본값은 AttributeTargets.All 입니다.

  • 매개 변수 allowmultiple (선택 사항) 은이 특성의 AllowMultiple 속성 값인 부울 값을 제공합니다. 이것이 사실이면 속성은 다중 사용입니다. 기본값은 false (일회용)입니다.

  • inherited (선택 사항) 매개 변수 는이 특성 의 Inherited 속성 값인 부울 값을 제공합니다. true이면 속성이 파생 클래스에 상속됩니다. 기본값은 false (상속되지 않음)입니다.

예를 들면

[AttributeUsage(
   AttributeTargets.Class |
   AttributeTargets.Constructor |
   AttributeTargets.Field |
   AttributeTargets.Method |
   AttributeTargets.Property, 
   AllowMultiple = true)]

가정 어구

이 미리 정의 된 속성은 지정된 전처리 식별자에 따라 실행되는 조건부 메서드를 표시합니다.

다음과 같은 지정된 값에 따라 메서드 호출의 조건부 컴파일이 발생합니다. Debug 또는 Trace. 예를 들어 코드를 디버깅하는 동안 변수 값을 표시합니다.

이 속성을 지정하는 구문은 다음과 같습니다.

[Conditional(
   conditionalSymbol
)]

예를 들면

[Conditional("DEBUG")]

다음 예제는 속성을 보여줍니다-

#define DEBUG
using System;
using System.Diagnostics;

public class Myclass {
   [Conditional("DEBUG")]
   
   public static void Message(string msg) {
      Console.WriteLine(msg);
   }
}
class Test {
   static void function1() {
      Myclass.Message("In Function 1.");
      function2();
   }
   static void function2() {
      Myclass.Message("In Function 2.");
   }
   public static void Main() {
      Myclass.Message("In Main function.");
      function1();
      Console.ReadKey();
   }
}

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

In Main function
In Function 1
In Function 2

구식

이 사전 정의 된 속성은 사용해서는 안되는 프로그램 엔티티를 표시합니다. 특정 대상 요소를 삭제하도록 컴파일러에 알릴 수 있습니다. 예를 들어, 새로운 메서드가 클래스에서 사용 중이고 클래스에서 이전 메서드를 계속 유지하려는 경우 이전 메서드 대신 새 메서드를 사용해야한다는 메시지를 표시하여 사용되지 않음으로 표시 할 수 있습니다.

이 속성을 지정하는 구문은 다음과 같습니다.

[Obsolete (
   message
)]

[Obsolete (
   message,
   iserror
)]

어디,

  • message 매개 변수 는 항목이 폐기 된 이유와 대신 사용할 항목을 설명하는 문자열입니다.

  • 매개 변수 iserror 는 부울 값입니다. 값이 true이면 컴파일러는 항목 사용을 오류로 처리해야합니다. 기본값은 false입니다 (컴파일러가 경고를 생성 함).

다음 프로그램은 이것을 보여줍니다-

using System;

public class MyClass {
   [Obsolete("Don't use OldMethod, use NewMethod instead", true)]
   
   static void OldMethod() {
      Console.WriteLine("It is the old method");
   }
   static void NewMethod() {
      Console.WriteLine("It is the new method"); 
   }
   public static void Main() {
      OldMethod();
   }
}

프로그램을 컴파일하려고하면 컴파일러는 다음과 같은 오류 메시지를 표시합니다.

Don't use OldMethod, use NewMethod instead

사용자 지정 속성 생성

.Net Framework를 사용하면 선언적 정보를 저장하는 데 사용할 수 있고 런타임에 검색 할 수있는 사용자 지정 특성을 만들 수 있습니다. 이 정보는 설계 기준 및 애플리케이션 요구에 따라 모든 대상 요소와 관련 될 수 있습니다.

사용자 지정 속성을 만들고 사용하려면 4 단계가 필요합니다.

  • 사용자 정의 속성 선언
  • 사용자 정의 속성 생성
  • 대상 프로그램 요소에 사용자 정의 속성 적용
  • 리플렉션을 통해 속성에 액세스

마지막 단계는 다양한 표기법을 찾기 위해 메타 데이터를 읽는 간단한 프로그램을 작성하는 것입니다. 메타 데이터는 다른 데이터를 설명하는 데 사용되는 데이터 또는 정보에 대한 데이터입니다. 이 프로그램은 런타임에 속성에 액세스하기 위해 리플렉션을 사용해야합니다. 이것은 다음 장에서 논의 할 것입니다.

사용자 지정 속성 선언

새 사용자 정의 속성은 System.Attribute수업. 예를 들면

//a custom attribute BugFix to be assigned to a class and its members
[AttributeUsage(
   AttributeTargets.Class |
   AttributeTargets.Constructor |
   AttributeTargets.Field |
   AttributeTargets.Method |
   AttributeTargets.Property,
   AllowMultiple = true)]

public class DeBugInfo : System.Attribute

앞의 코드에서 DeBugInfo 라는 사용자 지정 속성을 선언했습니다 .

사용자 정의 속성 구성

프로그램을 디버깅하여 얻은 정보를 저장하는 DeBugInfo 라는 사용자 지정 속성을 생성 해 보겠습니다 . 다음 정보를 저장하십시오-

  • 버그의 코드 번호
  • 버그를 식별 한 개발자의 이름
  • 코드의 마지막 검토 날짜
  • 개발자의 의견을 저장하기위한 문자열 메시지

따라서 debuginfo의 클래스는 처음 세 정보와 메시지들을 저장하기위한 공용 속성을 저장하기위한 세 개인 속성을 갖는다. 따라서 버그 번호, 개발자 이름 및 검토 날짜는 DeBugInfo 클래스의 위치 매개 변수이며 메시지는 선택적 또는 명명 된 매개 변수입니다.

각 속성에는 생성자가 하나 이상 있어야합니다. 위치 매개 변수는 생성자를 통해 전달되어야합니다. 다음 코드는 DeBugInfo 클래스를 보여줍니다 -

//a custom attribute BugFix to be assigned to a class and its members
[AttributeUsage(
   AttributeTargets.Class |
   AttributeTargets.Constructor |
   AttributeTargets.Field |
   AttributeTargets.Method |
   AttributeTargets.Property,
   AllowMultiple = true)]

public class DeBugInfo : System.Attribute {
   private int bugNo;
   private string developer;
   private string lastReview;
   public string message;
   
   public DeBugInfo(int bg, string dev, string d) {
      this.bugNo = bg;
      this.developer = dev;
      this.lastReview = d;
   }
   public int BugNo {
      get {
         return bugNo;
      }
   }
   public string Developer {
      get {
         return developer;
      }
   }
   public string LastReview {
      get {
         return lastReview;
      }
   }
   public string Message {
      get {
         return message;
      }
      set {
         message = value;
      }
   }
}

사용자 정의 속성 적용

속성은 대상 바로 앞에 배치하여 적용됩니다-

[DeBugInfo(45, "Zara Ali", "12/8/2012", Message = "Return type mismatch")]
[DeBugInfo(49, "Nuha Ali", "10/10/2012", Message = "Unused variable")]
class Rectangle {
   //member variables
   protected double length;
   protected double width;
   public Rectangle(double l, double w) {
      length = l;
      width = w;
   }
   [DeBugInfo(55, "Zara Ali", "19/10/2012", Message = "Return type mismatch")]
   
   public double GetArea() {
      return length * width;
   }
   [DeBugInfo(56, "Zara Ali", "19/10/2012")]
   
   public void Display() {
      Console.WriteLine("Length: {0}", length);
      Console.WriteLine("Width: {0}", width);
      Console.WriteLine("Area: {0}", GetArea());
   }
}

다음 장에서는 Reflection 클래스 객체를 사용하여 속성 정보를 검색합니다.