이 문서는 기계 번역을 이용하여 번역되었습니다. 문서를 영문으로 보려면 영문 확인란을 선택하세요. 마우스 포인터를 텍스트 위로 이동시켜 팝업 창에서 영문 텍스트를 표시할 수도 있습니다.
번역
영문

IFormatProvider.GetFormat 메서드 (Type)

 

게시 날짜: 2016년 11월

지정된 된 형식에 대 한 형식 지정 서비스를 제공 하는 개체를 반환 합니다.

네임스페이스:   System
어셈블리:  mscorlib(mscorlib.dll에 있음)

object GetFormat(
	Type formatType
)

매개 변수

formatType
Type: System.Type

반환할 형식 개체의 형식을 지정 하는 개체입니다.

반환 값

Type: System.Object

지정한 개체의 인스턴스 formatType경우는 IFormatProvider 구현에서 해당 유형의 개체를 제공할 수, 그렇지 않으면 null합니다.

GetFormat작업 또는 서식 지정 작업에는 출력 문자열의 형식을 구문 분석에 입력된 문자열의 형식에 대 한 정보를 검색할 서식 지정 및 구문 분석 메서드를 호출 하는 콜백 메서드입니다.formatType 매개 변수, 형식 지정 또는 구문 분석 방법에는 해당 작업을 수행 하는 데 필요한 개체 유형을 전달 합니다. 경우는 IFormatProvider 구현을 제공할 수 있습니다이 서식 지정 또는 해당 개체가 반환 개체를 구문 분석 합니다. 반환 된 그렇지 않은 경우 null합니다.

예를 들어 호출에에서는 Int32.ToString(IFormatProvider) 메서드에서 메서드 인수는는 IFormatProvider 정수는 현재 인스턴스의 문자열 표현의 서식을 지정할 수 있습니다 어떻게 하는 방법에 대 한 정보를 제공 하는 개체입니다. 런타임에서 메서드를 실행할 경우 호출 하는 IFormatProvider 개체의 GetFormat 메서드 전달는 Type 을 나타내는 개체는 NumberFormatInfo 형식. 경우는 IFormatProvider 제공할 수는 NumberFormatInfo 해당 개체를 반환 합니다. 반환 하는 경우 해당 형식의 개체를 제공할 수 없으면, null합니다.

구현할 수는 IFormatProvider 인터페이스 및 GetFormat 사용자 지정 서식 지정 또는 구문 분석 서비스를 제공 하는 클래스는 메서드. IFormatProvider 이후에 구현이 구문 분석 또는 형식 지정 메서드의 형식 매개 변수를 가진 모든 오버 로드를 인수로 전달 됩니다 IFormatProvider와 같은 String.Format(IFormatProvider, String, Object[]), Int32.ToString(String, IFormatProvider), 또는 DateTime.Parse(String, IFormatProvider)합니다.

다음 예제에서는 구현 하는 클래스를 사용 하는 IFormatProvider 인터페이스 및 GetFormat 메서드. AcctNumberFormat 클래스는 Int64 12 자리 계정 형식이 지정 된 수로 계정 번호를 나타내는 값입니다. 해당 GetFormat 경우 자신에 대 한 참조를 반환 하는 메서드는 formatType 매개 변수를 구현 하는 클래스를 참조 ICustomFormatter, 그렇지 않으면 GetFormat 반환 null합니다.

public class AcctNumberFormat : IFormatProvider, ICustomFormatter
{
   private const int ACCT_LENGTH = 12;

   public object GetFormat(Type formatType)
   {
      if (formatType == typeof(ICustomFormatter))
         return this;
      else
         return null;
   }

   public string Format(string fmt, object arg, IFormatProvider formatProvider) 
   {
      // Provide default formatting if arg is not an Int64.
      if (arg.GetType() != typeof(Int64))
         try {
            return HandleOtherFormats(fmt, arg); 
         }
         catch (FormatException e) {
            throw new FormatException(String.Format("The format of '{0}' is invalid.", fmt), e);
         }

      // Provide default formatting for unsupported format strings.
      string ufmt = fmt.ToUpper(CultureInfo.InvariantCulture);
      if (! (ufmt == "H" || ufmt == "I")) 
         try {
            return HandleOtherFormats(fmt, arg);
         }
         catch (FormatException e) {
            throw new FormatException(String.Format("The format of '{0}' is invalid.", fmt), e);
         }

      // Convert argument to a string.
      string result = arg.ToString();

      // If account number is less than 12 characters, pad with leading zeroes.
      if (result.Length < ACCT_LENGTH)
         result = result.PadLeft(ACCT_LENGTH, '0');
      // If account number is more than 12 characters, truncate to 12 characters.
      if (result.Length > ACCT_LENGTH)
         result = result.Substring(0, ACCT_LENGTH);   

      if (ufmt == "I")                    // Integer-only format. 
         return result;
      // Add hyphens for H format specifier.
      else                                         // Hyphenated format.
         return result.Substring(0, 5) + "-" + result.Substring(5, 3) + "-" + result.Substring(8);
   }

   private string HandleOtherFormats(string format, object arg)
   {
      if (arg is IFormattable) 
         return ((IFormattable)arg).ToString(format, CultureInfo.CurrentCulture);
      else if (arg != null)
         return arg.ToString();
      else
         return String.Empty;
   }
}

인스턴스는 AcctNumberFormat 클래스 수 서식 지정 또는 구문 분석 서비스를 제공 하는 메서드를 다음 인수로 전달 하는 수입니다. 예를 들어 다음 코드 패스는 AcctNumberFormat 에 클래스는 String.Format(IFormatProvider, String, Object[]) 서식이 지정 된 12 자리 계정 번호를 생성 하는 메서드.

using System;
using System.Globalization;

public enum DaysOfWeek { Monday=1, Tuesday=2 };

public class TestFormatting
{
   public static void Main()
   {
      long acctNumber;
      double balance; 
      DaysOfWeek wday; 
      string output;

      acctNumber = 104254567890;
      balance = 16.34;
      wday = DaysOfWeek.Monday;

      output = String.Format(new AcctNumberFormat(), 
                             "On {2}, the balance of account {0:H} was {1:C2}.", 
                             acctNumber, balance, wday);
      Console.WriteLine(output);

      wday = DaysOfWeek.Tuesday;
      output = String.Format(new AcctNumberFormat(), 
                             "On {2}, the balance of account {0:I} was {1:C2}.", 
                             acctNumber, balance, wday);
      Console.WriteLine(output);
   }
}
// The example displays the following output:
//       On Monday, the balance of account 10425-456-7890 was $16.34.
//       On Tuesday, the balance of account 104254567890 was $16.34.

유니버설 Windows 플랫폼
8 이후 사용 가능
.NET Framework
1.1 이후 사용 가능
이식 가능한 클래스 라이브러리
이식 가능한 .NET 플랫폼 에서 지원됨
Silverlight
2.0 이후 사용 가능
Windows Phone Silverlight
7.0 이후 사용 가능
Windows Phone
8.1 이후 사용 가능
맨 위로 이동
표시: