System.IFormatProvider 接口

方法描述

提供用于检索控制格式化的对象的机制。

语法定义(C# System.IFormatProvider 接口 的用法)

[ComVisibleAttribute(true)]
public interface IFormatProvider

构造函数

构造函数名称 构造函数描述

成员/方法

方法名称 方法描述
GetFormat 返回一个对象,该对象为指定类型提供格式设置服务。

提示和注释

IFormatProvider 接口提供了一个对象,该对象提供格式设置信息用于格式设置和分析操作。 格式设置操作将类型的值转换为该值的字符串表示形式。 典型的格式设置方法包括类型的 ToString 方法以及 Format。 分析操作将值的字符串表示形式转换为具有该值的类型。 典型的分析方法包括 Parse 和 TryParse。

IFormatProvider 接口由一个方法构成:IFormatProvider.GetFormat。 GetFormat 为回调方法:分析或格式设置方法可以将其调用并传递至一个 Type 对象,该对象表示格式或设置分析方法要求提供格式设置信息的对象类型。 GetFormat 方法负责返回该类型的对象。

IFormatProvider 实现经常通过格式设置和分析方法来隐式使用。 例如,DateTime.ToString(String) 方法隐式使用 IFormatProvider 实现表示系统的当前区域性。 还可以通过具有 IFormatProvider 类型的参数的方法(Int32.Parse(String, IFormatProvider) 和 String.Format(IFormatProvider, String, Object[]))来显式指定 IFormatProvider 实现。

.NET Framework 包括以下三个预定义的 IFormatProvider 实现,以提供在格式设置或分析数值和日期和时间值中使用的特定于区域性的信息:

NumberFormatInfo 类可为特定区域提供用于设置数字格式的信息,例如货币符号、千位分隔符和小数点分隔符。

DateTimeFormatInfo 类,提供用于设置日期和时间格式的信息,如用于特定区域性的日期和时间分隔符符号,或者日期的年、月和日部分的顺序和格式。

CultureInfo 类,表示一个特殊的区域性。 它的 GetFormat 方法返回特定于区域性的 NumberFormatInfo 或 DateTimeFormatInfo 对象,取决于涉及数字或日期和时间的一个格式设置或分析操作中是否使用了 CultureInfo 对象是否。

.NET Framework 还支持自定义格式。 这通常需要创建格式设置类,而该类将实现 IFormatProvider 和 ICustomFormatter。 然后将此类的实例作为参数传递给执行自定义格式设置操作的方法,例如 String.Format(IFormatProvider, String, Object[]);本示例为这种将数字的格式设置为 12 位帐号的自定义实现提供了说明。

System.IFormatProvider 接口例子

例如,下面的代码调用 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.

继承层次结构

命名空间

namespace: System

程序集: mscorlib(在 mscorlib.dll 中)

线程安全

版本信息

.NET Framework 受以下版本支持:4、3.5、3.0、2.0、1.1、1.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1 受以下版本支持:

适用平台

Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。