指定 CultureInfo

更新:2007 年 11 月

TypeName

SpecifyCultureInfo

CheckId

CA1304

类别

Microsoft.Globalization

是否重大更改

原因

某方法或构造函数调用的方法具有一个以 System.Globalization.CultureInfo 作为参数的重载,且该方法或构造函数并不调用以 CultureInfo 为参数的重载。该规则忽略对下列方法的调用:

规则说明

如果未提供 CultureInfoSystem.IFormatProvider 对象,则重载成员提供的默认值可能不会在所有区域设置中产生想要的影响。另外,.NET Framework 成员会根据对您的代码来说可能不正确的假设来选择默认区域性和格式设置。要确保代码在您的环境中按预期运行,应根据下列准则提供区域性特定的信息:

  • 如果值将显示给用户,请使用当前区域性。请参见 CultureInfo.CurrentCulture

  • 如果值将由软件来存储(即,保存到文件或数据库)和访问,请使用固定区域性。请参见 CultureInfo.InvariantCulture

  • 如果不知道值的目标,请让数据使用者或数据提供者来指定区域性。

请注意,CultureInfo.CurrentUICulture 仅用于使用 System.Resources.ResourceManager 类的实例检索本地化资源。

即使重载成员的默认行为适合您的需要,也最好显式调用区域性特定的重载,这样您的代码将是自描述代码且更易于维护。

如何修复冲突

要修复与该规则的冲突,请使用以 CultureInfoIFormatProvider 为参数的重载,并根据以上列出的准则指定参数。

何时禁止显示警告

如果确定默认区域性/格式提供者的确是正确选择,且代码可维护性不是开发时应优先考虑的重要问题,则可以安全地禁止显示此规则发出的警告。

示例

在下面的示例中,BadMethod 会导致与该规则的两次冲突。GoodMethod 通过将固定区域性传递到 System.String.Compare 来更正第一次冲突,并通过将当前区域性传递到 ToLower 来更正第二次冲突(因为 string3 将会显示给用户)。

using System;
using System.Globalization;

namespace GlobalizationLibrary
{
    public class CultureInfoTest
    {
        public void BadMethod(String string1, String string2, String string3)
        {
            if(string.Compare(string1, string2, false) == 0)
            {
                Console.WriteLine(string3.ToLower());
            }
        }

        public void GoodMethod(String string1, String string2, String string3)
        {
            if(string.Compare(string1, string2, false, 
                              CultureInfo.InvariantCulture) == 0)
            {
                Console.WriteLine(string3.ToLower(CultureInfo.CurrentCulture));
            }
        }
    }
}

下面的示例演示当前区域性对 DateTime 类型选择的默认 IFormatProvider 的影响。

using System;
using System.Globalization;
using System.Threading;

namespace GlobalLibGlobalLibrary
{
    public class IFormatProviderTest
    {
        public static void Main()
        {
            string dt = "6/4/1900 12:15:12";

            // The default behavior of DateTime.Parse is to use
            // the current culture.

            // Violates rule: SpecifyIFormatProvider.
            DateTime myDateTime = DateTime.Parse(dt);
            Console.WriteLine(myDateTime);

            // Change the current culture to the French culture,
            // and parsing the same string yields a different value.

            Thread.CurrentThread.CurrentCulture = new CultureInfo("Fr-fr", true);
            myDateTime = DateTime.Parse(dt);

            Console.WriteLine(myDateTime);
        }
    }
}

该示例产生下面的输出:

6/4/1900 12:15:12 PM
06/04/1900 12:15:12

相关规则

指定 IFormatProvider

请参见

概念

使用 CultureInfo 类