이 문서는 이 API에 대한 참조 설명서를 보충하는 추가 설명을 제공합니다.
다음 지침은 모든 오버로드에 적용됩니다.
- 속성은 공용 접근자가 하나 이상 있으면 리플렉션에서 공용으로 간주됩니다. 그렇지 않으면 속성이 프라이빗으로 간주되며, 속성을 얻으려면 BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Static를 사용해야 합니다 (Visual Basic에서는
Or를 사용하여 값을 결합합니다). - 현재 Type 가 생성된 제네릭 형식을 나타내는 경우 이 메서드는 적절한 형식 인수로 대체된 형식 매개 변수를 반환 PropertyInfo 합니다.
- 현재 Type 제네릭 형식 또는 제네릭 메서드 정의에서 형식 매개 변수를 나타내는 경우 이 메서드는 클래스 제약 조건의 속성을 검색합니다.
GetProperty(String) 메서드
검색에서 name은 대/소문자를 구분합니다. 검색에는 공용 정적 및 공용 인스턴스 속성이 포함됩니다.
발생하는 상황에는 AmbiguousMatchException 다음이 포함됩니다.
- 형식에는 이름이 같지만 매개 변수 수가 다른 두 개의 인덱싱된 속성이 포함됩니다. 모호성을 해결하려면 매개 변수 형식을 지정하는 메서드의 GetProperty 오버로드를 사용합니다.
- 파생 형식은
new한정자를 사용하여 동일한 이름의 상속된 속성을 가리는 속성을 선언하며, 이는 Visual Basic에서Shadows한정자를 사용합니다. 모호성을 해결하려면 메서드 오버로드를 GetProperty(String, BindingFlags) 사용하고 플래그를 BindingFlags.DeclaredOnly 추가하여 상속되지 않은 멤버로 검색을 제한합니다.
GetProperty(String, BindingFlags) 메서드
다음 BindingFlags 필터 플래그를 사용하여 검색에 포함할 속성을 정의할 수 있습니다.
- 반환을 얻으려면
BindingFlags.Instance또는BindingFlags.Static중 하나를 지정해야 합니다. - 검색에 공용 속성을 포함하도록 지정
BindingFlags.Public합니다. - 검색에 public이 아닌 속성(즉, 프라이빗, 내부 및 보호된 속성)을 포함하도록 지정
BindingFlags.NonPublic합니다. - 위계에서
BindingFlags.FlattenHierarchy및public정적 멤버를 포함하도록protected을(를) 지정하세요. 상속된 클래스에서는private정적 멤버가 포함되지 않습니다.
다음 BindingFlags 한정자 플래그를 사용하여 검색 작동 방식을 변경할 수 있습니다.
-
BindingFlags.IgnoreCase의 대소문자를 무시합니다. -
BindingFlags.DeclaredOnly단순히 상속된 속성을 검색하지 않고 Type에 선언된 속성만 검색합니다.
발생하는 상황에는 AmbiguousMatchException 다음이 포함됩니다.
- 형식에는 이름이 같지만 매개 변수 수가 다른 두 개의 인덱싱된 속성이 포함됩니다. 모호성을 해결하려면 매개 변수 형식을 지정하는 메서드의 GetProperty 오버로드를 사용합니다.
- 파생된 형식은
new한정자(ShadowsVisual Basic)를 사용하여 동일한 이름의 상속된 속성을 숨기는 속성을 선언합니다. 모호성을 해결하려면 상속되지 않은 멤버로 검색을 제한하도록 포함합니다 BindingFlags.DeclaredOnly .
GetProperty(System.String, System.Reflection.BindingFlags, System.Reflection.Binder, System.Type, System.Type[], System.Reflection.ParameterModifier[]) 메서드
기본 바인더는 ParameterModifier를 처리하지 않지만 (modifiers 매개 변수) 추상 System.Reflection.Binder 클래스를 사용하여 modifiers를 처리하는 사용자 지정 바인더를 작성할 수 있습니다.
ParameterModifier 는 COM interop을 통해 호출할 때만 사용되며 참조로 전달되는 매개 변수만 처리됩니다.
다음 표에서는 형식을 반영할 때 메서드에서 반환되는 기본 클래스의 Get 멤버를 보여 줍니다.
| 멤버 형식 | 정적인 | 비정적 |
|---|---|---|
| 생성자 | 아니오 | 아니오 |
| 분야 | 아니오 | 예. 필드는 항상 이름과 서명을 기준으로 숨겨집니다. |
| 이벤트 | 해당 없음 | 일반적인 형식 시스템 규칙은 상속이 속성을 구현하는 메서드의 상속과 동일하다는 것입니다. 반영은 속성을 이름 및 서명에 따라 숨김 처리합니다. 2 |
| 메서드 | 아니오 | 예. 메서드(가상 및 가상이 아닌 메서드)는 이름으로 숨기기 또는 이름과 서명으로 숨기기가 가능합니다. |
| 중첩 타입 | 아니오 | 아니오 |
| 재산 | 해당 없음 | 일반적인 형식 시스템 규칙은 상속이 속성을 구현하는 메서드의 상속과 동일하다는 것입니다. 반영은 속성을 이름 및 서명에 따라 숨김 처리합니다. 2 |
노트:
- 이름별 및 서명에 의한 숨기기는 사용자 지정 한정자, 반환 형식, 매개 변수 형식, 센티넬 및 비관리 호출 규칙을 포함하여 서명의 모든 부분을 고려합니다. 이진 비교입니다.
- 리플렉션의 경우 속성과 이벤트는 이름 및 서명별로 숨겨집니다. 기본 클래스에 get 및 set 접근자가 모두 있는 속성이 있지만 파생 클래스에 get 접근자만 있는 경우 파생 클래스 속성은 기본 클래스 속성을 숨기며 기본 클래스의 setter에 액세스할 수 없습니다.
- 사용자 지정 특성은 공용 형식 시스템의 일부가 아닙니다.
다음 BindingFlags 필터 플래그를 사용하여 검색에 포함할 속성을 정의할 수 있습니다.
- 반환을 얻으려면
BindingFlags.Instance또는BindingFlags.Static중 하나를 지정해야 합니다. - 검색에 공용 속성을 포함하도록 지정
BindingFlags.Public합니다. - 검색에 public이 아닌 속성(즉, 프라이빗, 내부 및 보호된 속성)을 포함하도록 지정
BindingFlags.NonPublic합니다. - 위계에서
BindingFlags.FlattenHierarchy및public정적 멤버를 포함하도록protected을(를) 지정하세요. 상속된 클래스에서는private정적 멤버가 포함되지 않습니다.
다음 BindingFlags 한정자 플래그를 사용하여 검색 작동 방식을 변경할 수 있습니다.
-
BindingFlags.IgnoreCase의 대소문자를 무시합니다. -
BindingFlags.DeclaredOnly단순히 상속된 속성을 검색하지 않고 Type에 선언된 속성만 검색합니다.
인덱서 및 기본 속성
Visual Basic, C# 및 C++에는 인덱싱된 속성에 액세스하기 위한 구문이 간소화되었으며 인덱싱된 속성 하나가 해당 형식의 기본값이 되도록 허용합니다. 예를 들어 변수 myList가 ArrayList를 참조하는 경우, Visual Basic 에서 myList[3] (myList(3) 사용)의 구문은 인덱스가 3인 요소를 검색합니다. 속성을 오버로드할 수 있습니다.
C#에서 이 기능을 인덱서라고 하며 이름으로 참조할 수 없습니다. 기본적으로 C# 인덱서는 메타데이터에 이름이 Item인 인덱싱된 속성으로 나타납니다. 그러나 클래스 라이브러리 개발자는 특성을 사용하여 IndexerNameAttribute 메타데이터에서 인덱서의 이름을 변경할 수 있습니다. 예를 들어, String 클래스에는 Chars[]이라는 이름의 인덱서가 있습니다. C# 이외의 언어를 사용하여 만든 인덱싱된 속성에는 다른 Item이름도 있을 수 있습니다.
형식에 기본 속성이 있는지 확인하려면 GetCustomAttributes(Type, Boolean) 메서드를 사용하여 DefaultMemberAttribute 특성을 테스트합니다. 형식 DefaultMemberAttribute이 있는 경우 속성은 MemberName 기본 속성의 이름을 반환합니다.
.NET