Thread.CurrentUICulture Свойство

Определение

Получает или задает текущие язык и региональные параметры, используемые диспетчером ресурсов для поиска ресурсов, связанных с языком и региональными параметрами, во время выполнения.Gets or sets the current culture used by the Resource Manager to look up culture-specific resources at run time.

public:
 property System::Globalization::CultureInfo ^ CurrentUICulture { System::Globalization::CultureInfo ^ get(); void set(System::Globalization::CultureInfo ^ value); };
public System.Globalization.CultureInfo CurrentUICulture { get; set; }
member this.CurrentUICulture : System.Globalization.CultureInfo with get, set
Public Property CurrentUICulture As CultureInfo

Значение свойства

Объект, представляющий текущие языковые стандарты.An object that represents the current culture.

Исключения

Для свойства задано значение null.The property is set to null.

Свойству присвоено имя языка и региональных параметров, которое не может использоваться для нахождения файла ресурсов.The property is set to a culture name that cannot be used to locate a resource file. Имена файлов ресурсов могут содержать только буквы, цифры, дефисы или символы подчеркивания.Resource filenames must include only letters, numbers, hyphens or underscores.

Только в .NET Core. Чтение или запись данных о языке и региональных параметрах потока из другого потока не поддерживается..NET Core only: Reading or writing the culture of a thread from another thread is not supported.

Примеры

В следующем примере определяется, является ли язык языка и региональных параметров пользовательского интерфейса для текущего потока французским.The following example determines whether the language of the current thread's UI culture is French. В противном случае он устанавливает язык и региональные параметры пользовательского интерфейса для текущего потока на английский (США).If it is not, it sets the UI culture of the current thread to English (United States).

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

public class Example
{
   public static void Main()
   {
      // Change the current culture if the language is not French.
      CultureInfo current = Thread.CurrentThread.CurrentUICulture;
      if (current.TwoLetterISOLanguageName != "fr") {
         CultureInfo newCulture = CultureInfo.CreateSpecificCulture("en-US");
         Thread.CurrentThread.CurrentUICulture = newCulture;
         // Make current UI culture consistent with current culture.
         Thread.CurrentThread.CurrentCulture = newCulture;
      }
      Console.WriteLine("The current UI culture is {0} [{1}]",
                        Thread.CurrentThread.CurrentUICulture.NativeName,
                        Thread.CurrentThread.CurrentUICulture.Name);
      Console.WriteLine("The current culture is {0} [{1}]",
                        Thread.CurrentThread.CurrentUICulture.NativeName,
                        Thread.CurrentThread.CurrentUICulture.Name);
   }
}
// The example displays the following output:
//     The current UI culture is English (United States) [en-US]
//     The current culture is English (United States) [en-US]
Imports System.Globalization
Imports System.Threading

Module Example
   Public Sub Main()
      ' Change the current culture if the language is not French.
      Dim current As CultureInfo = Thread.CurrentThread.CurrentUICulture
      If current.TwoLetterISOLanguageName <> "fr" Then
         Dim newCulture As CultureInfo = CultureInfo.CreateSpecificCulture("en-US")
         Thread.CurrentThread.CurrentUICulture = newCulture
         ' Make current UI culture consistent with current culture.
         Thread.CurrentThread.CurrentCulture = newCulture
      End If
      Console.WriteLine("The current UI culture is {0} [{1}]",
                        Thread.CurrentThread.CurrentUICulture.NativeName,
                        Thread.CurrentThread.CurrentUICulture.Name)
      Console.WriteLine("The current culture is {0} [{1}]",
                        Thread.CurrentThread.CurrentUICulture.NativeName,
                        Thread.CurrentThread.CurrentUICulture.Name)
   End Sub
End Module
' The example displays output like the following:
'     The current UI culture is English (United States) [en-US]
'     The current culture is English (United States) [en-US]

В следующем примере кода показана инструкция для работы с потоками, которая позволяет пользовательскому интерфейсу Windows Forms отображаться в культуре, заданной в панели управления.The following code example shows the threading statement that allows the user interface of a Windows Forms to display in the culture that is set in Control Panel. Требуется дополнительный код.Additional code is needed.

#using <system.dll>
#using <System.Drawing.dll>
#using <system.windows.forms.dll>

using namespace System;
using namespace System::Threading;
using namespace System::Windows::Forms;
ref class UICulture: public Form
{
public:
   UICulture()
   {
      
      // Set the user interface to display in the
      // same culture as that set in Control Panel.
      Thread::CurrentThread->CurrentUICulture = Thread::CurrentThread->CurrentCulture;
      
      // Add additional code.
   }
};


int main()
{
   Application::Run( gcnew UICulture );
}
using System;
using System.Threading;
using System.Windows.Forms;

class UICulture : Form
{
    public UICulture()
    {
        // Set the user interface to display in the
        // same culture as that set in Control Panel.
        Thread.CurrentThread.CurrentUICulture = 
            Thread.CurrentThread.CurrentCulture;

        // Add additional code.
    }

    static void Main()
    {
        Application.Run(new UICulture());
    }
}
Imports System.Threading
Imports System.Windows.Forms

Public Class UICulture : Inherits Form
    Sub New()

        ' Set the user interface to display in the
        ' same culture as that set in Control Panel.
        Thread.CurrentThread.CurrentUICulture = _
            Thread.CurrentThread.CurrentCulture

        ' Add additional code.
    End Sub

    Shared Sub Main()
        Application.Run(New UICulture())
    End Sub
End Class

Комментарии

Язык и региональные параметры пользовательского интерфейса указывают ресурсы, необходимые приложению для поддержки ввода и вывода данных пользователем, и по умолчанию совпадает с культурой операционной системы.The UI culture specifies the resources an application needs to support user input and output, and by default is the same as the operating system culture. Сведения об именах и идентификаторах языков и региональных параметров, различиях между инвариантными, нейтральными и конкретными культурами, а также о том, как язык и региональные параметры влияют на потоки и домены приложений, см. в разделе класс CultureInfoSee the CultureInfo class to learn about culture names and identifiers, the differences between invariant, neutral, and specific cultures, and the way culture information affects threads and application domains. Сведения о том, как определяется язык и региональные параметры пользовательского интерфейса по умолчанию для потока, см. в описании свойства CultureInfo.CurrentUICulture.See the CultureInfo.CurrentUICulture property to learn how a thread's default UI culture is determined.

Важно!

Свойство CurrentUICulture не работает надежно при использовании в любом потоке, отличном от текущего потока.The CurrentUICulture property doesn't work reliably when used with any thread other than the current thread. В .NET Framework чтение свойства является надежным, хотя его задание для потока, отличного от текущего потока, — нет.In .NET Framework, reading the property is reliable, although setting it for a thread other than the current thread is not. В .NET Core создается InvalidOperationException, если поток пытается прочитать или записать свойство CurrentUICulture в другом потоке.On .NET Core, an InvalidOperationException is thrown if a thread attempts to read or write the CurrentUICulture property on a different thread. Для получения и задания текущего языка и региональных параметров рекомендуется использовать свойство CultureInfo.CurrentUICulture.We recommend that you use the CultureInfo.CurrentUICulture property to retrieve and set the current culture.

CultureInfo, возвращаемое этим свойством, может быть нейтральным языком и региональными параметрами.The CultureInfo returned by this property can be a neutral culture. Нейтральные языки и региональные параметры не следует использовать с такими методами форматирования, как String.Format(IFormatProvider, String, Object[]), DateTime.ToString(String, IFormatProvider)и Convert.ToString(Char, IFormatProvider).Neutral cultures should not be used with formatting methods such as String.Format(IFormatProvider, String, Object[]), DateTime.ToString(String, IFormatProvider), and Convert.ToString(Char, IFormatProvider). Используйте метод CultureInfo.CreateSpecificCulture для получения определенного языка и региональных параметров или используйте свойство CurrentCulture.Use the CultureInfo.CreateSpecificCulture method to get a specific culture, or use the CurrentCulture property.

Примечание

Метод CultureInfo.CreateSpecificCulture вызывает ArgumentException для нейтральных языков и региональных параметров "zh-Hant" ("zh-CHT") и "zh-Ханс" ("zh-CHS").The CultureInfo.CreateSpecificCulture method throws ArgumentException for the neutral cultures "zh-Hant" ("zh-CHT") and "zh-Hans" ("zh-CHS").

Применяется к