MissingFieldException 클래스

2013-12-13

존재하지 않는 필드를 동적으로 액세스하려고 할 때 발생되는 예외입니다.

System.Object
  System.Exception
    System.SystemException
      System.MemberAccessException
        System.MissingMemberException
          System.MissingFieldException

Namespace:  System
어셈블리:  mscorlib(mscorlib.dll)

public class MissingFieldException : MissingMemberException

MissingFieldException 형식에서는 다음과 같은 멤버를 노출합니다.

  이름설명
Public 메서드MissingFieldException()MissingFieldException 클래스의 새 인스턴스를 초기화합니다.
Public 메서드MissingFieldException(String)지정된 오류 메시지를 사용하여 MissingFieldException 클래스의 새 인스턴스를 초기화합니다.
Public 메서드MissingFieldException(String, Exception)지정된 오류 메시지와 해당 예외의 근본 원인인 내부 예외에 대한 참조를 사용하여 MissingFieldException 클래스의 새 인스턴스를 초기화합니다.
맨 위

  이름설명
Public 속성Data예외에 대한 사용자 정의 추가 정보를 제공하는 키/값 쌍의 컬렉션을 가져옵니다. (Exception에서 상속됨)
Public 속성HelpLink이 예외와 관련된 도움말 파일에 대한 링크를 가져오거나 설정합니다. (Exception에서 상속됨)
Public 속성HResult특정 예외에 할당된 코드화된 숫자 값인 HRESULT를 가져오거나 설정합니다. (Exception에서 상속됨)
Public 속성InnerException현재 예외를 발생시킨 Exception 인스턴스를 가져옵니다. (Exception에서 상속됨)
Public 속성Message손실된 멤버의 클래스 이름, 멤버 이름 및 서명을 나타내는 텍스트 문자열을 가져옵니다. (MissingMemberException에서 상속됨)
Public 속성Source오류를 발생시키는 응용프로그램 또는 개체의 이름을 가져오거나 설정합니다. (Exception에서 상속됨)
Public 속성StackTrace현재 예외가 발생된 시간에 호출 스택의 프레임에 대한 문자열 표현을 가져옵니다. (Exception에서 상속됨)
맨 위

  이름설명
Public 메서드Equals(Object)지정한 Object가 현재 Object와 같은지 확인합니다. (Object에서 상속됨)
Protected 메서드Finalize가비지 수집기에서 Object를 회수하기 전에 개체가 리소스를 해제하고 다른 정리 작업을 수행할 수 있게 합니다. (Object에서 상속됨)
Public 메서드GetBaseException파생 클래스에서 재정의되었을 때, 하나 이상의 후속 예외의 근본 원인이 되는 Exception을 반환합니다. (Exception에서 상속됨)
Public 메서드GetHashCode특정 형식에 대한 해시 함수 역할을 합니다. (Object에서 상속됨)
Public 메서드GetType현재 인스턴스의 런타임 형식을 가져옵니다. (Exception에서 상속됨)
Protected 메서드MemberwiseClone현재 Object의 단순 복사본을 만듭니다. (Object에서 상속됨)
Public 메서드ToString현재 예외에 대한 문자열 표현을 만들고 반환합니다. (Exception에서 상속됨)
맨 위

일반적으로 코드에서 존재하지 않는 클래스 멤버에 액세스하려고 하면 컴파일 오류가 발생합니다. MissingFieldException은 강력한 이름으로 참조되지 않는 어셈블리의 필드 중 이름이 바뀌었거나 삭제된 필드에 동적으로 액세스하려는 경우를 처리하기 위한 것입니다. 종속 어셈블리의 코드에서 수정된 어셈블리의 없는 필드에 액세스하려고 하면 MissingFieldException이 발생됩니다.

MissingFieldException은 0x80131511 값을 가지는 HRESULT COR_E_MISSINGFIELD를 사용합니다.

MissingFieldException 인스턴스의 초기 속성 값 목록에 대한 자세한 내용은 MissingFieldException 생성자를 참조하세요.

이 예제에서는 리플렉션을 사용하여 존재하지 않는 메서드를 호출하고 존재하지 않는 필드에 액세스하려고 하는 경우 어떠한 일이 발생하는지 보여 줍니다. 응용프로그램은 MissingMethodException, MissingFieldExceptionMissingMemberException을 처리하여 복구됩니다.

참고참고:

이 예제를 실행하려면 Windows Phone용 정적 TextBlock 컨트롤이 있는 예제 빌드를 참조하세요.


using System;
using System.Reflection;

public class Example
{
   public static void Demo(System.Windows.Controls.TextBlock outputBlock)
   {

      try
      {
         // Attempt to call a static DoSomething method defined in the Example class.
         // However, because the Example class does not define this field, 
         // a MissingFieldException is thrown.
         typeof(Example).InvokeMember("DoSomething", BindingFlags.Static |
             BindingFlags.InvokeMethod, null, null, null);
      }
      catch (MissingMethodException e)
      {
         // Show the user that the DoSomething method cannot be called.
         outputBlock.Text += String.Format("Unable to call the DoSomething method: {0}", e.Message) + "\n";
      }

      try
      {
         // Attempt to access a static AField field defined in the Example class.
         // However, because the Example class does not define this field, 
         // a MissingFieldException is thrown.
         typeof(Example).InvokeMember("AField", BindingFlags.Static | BindingFlags.SetField,
             null, null, new Object[] { 5 });
      }
      catch (MissingFieldException e)
      {
         // Show the user that the AField field cannot be accessed.
         outputBlock.Text += String.Format("Unable to access the AField field: {0}", e.Message) + "\n";
      }

      try
      {
         // Attempt to access a static AnotherField field defined in the Example class.
         // However, because the Example class does not define this field, 
         // a MissingFieldException is thrown.
         typeof(Example).InvokeMember("AnotherField", BindingFlags.Static |
             BindingFlags.GetField, null, null, null);
      }
      catch (MissingMemberException e)
      {
         // Notice that this code is catching MissingMemberException which is the  
         // base class of MissingMethodException and MissingFieldException.
         // Show the user that the AnotherField field cannot be accessed.
         outputBlock.Text += String.Format("Unable to access the AnotherField field: {0}", e.Message) + "\n";
      }
   }
}
// This code example produces the following output:
//
// Unable to call the DoSomething method: Method 'App.DoSomething' not found.
// Unable to access the AField field: Field 'App.AField' not found.
// Unable to access the AnotherField field: Field 'App.AnotherField' not found.


Windows Phone OS

지원되는 버전: 8.0, 7.1, 7.0

Windows Phone

이 형식의 모든 공용 static(Visual Basic의 경우 Shared) 멤버는 스레드로부터 안전합니다. 모든 인스턴스 멤버는 스레드로부터 안전하지 않을 수 있습니다.

표시:
© 2014 Microsoft