Propriété System.Globalization.CultureInfo.CurrentCulture

Cet article vous offre des remarques complémentaires à la documentation de référence pour cette API.

L’objet CultureInfo retourné par la CurrentCulture propriété et ses objets associés détermine le format par défaut pour les dates, les heures, les nombres et les valeurs monétaires, l’ordre de tri du texte, les conventions de casse et les comparaisons de chaînes.

La culture actuelle est une propriété du thread en cours d’exécution. Lorsque vous définissez cette propriété sur un CultureInfo objet qui représente une nouvelle culture, la valeur de la Thread.CurrentThread.CurrentCulture propriété change également. Toutefois, nous vous recommandons d’utiliser toujours la CultureInfo.CurrentCulture propriété pour récupérer et définir la culture actuelle.

L’objet CultureInfo retourné par cette propriété est en lecture seule. Cela signifie que vous ne pouvez pas muter l’objet existant, par exemple, en modifiant le DateTimeFormat. Pour modifier le format date-heure ou un autre aspect de la culture actuelle, créez un CultureInfo objet et affectez-le à la propriété.

Détermination de la culture d’un thread

Lorsqu’un thread est démarré, sa culture est initialement déterminée comme suit :

  • En récupérant la culture spécifiée par la DefaultThreadCurrentCulture propriété dans le domaine d’application dans lequel le thread s’exécute, si la valeur de la propriété n’est pas null.

  • Si le thread est un thread de pool de threads qui exécute une opération asynchrone basée sur des tâches, sa culture est déterminée par la culture du thread appelant. L’exemple suivant modifie la culture actuelle en Portugais (Brésil) et lance six tâches, chacune affichant son ID de thread, son ID de tâche et sa culture actuelle. Chacune des tâches (et les threads) a hérité de la culture du thread appelant.

    using System;
    using System.Collections.Generic;
    using System.Globalization;
    using System.Runtime.Versioning;
    using System.Threading;
    using System.Threading.Tasks;
    
    public class Example14
    {
        public static async Task Main()
        {
            var tasks = new List<Task>();
            Console.WriteLine("The current culture is {0}",
                              Thread.CurrentThread.CurrentCulture.Name);
            Thread.CurrentThread.CurrentCulture = new CultureInfo("pt-BR");
            // Change the current culture to Portuguese (Brazil).
            Console.WriteLine("Current culture changed to {0}",
                              Thread.CurrentThread.CurrentCulture.Name);
            Console.WriteLine("Application thread is thread {0}",
                              Thread.CurrentThread.ManagedThreadId);
            // Launch six tasks and display their current culture.
            for (int ctr = 0; ctr <= 5; ctr++)
                tasks.Add(Task.Run(() =>
                {
                    Console.WriteLine("Culture of task {0} on thread {1} is {2}",
                                      Task.CurrentId,
                                      Thread.CurrentThread.ManagedThreadId,
                                      Thread.CurrentThread.CurrentCulture.Name);
                }));
    
            await Task.WhenAll(tasks.ToArray());
        }
    }
    // The example displays output like the following:
    //     The current culture is en-US
    //     Current culture changed to pt-BR
    //     Application thread is thread 9
    //     Culture of task 2 on thread 11 is pt-BR
    //     Culture of task 1 on thread 10 is pt-BR
    //     Culture of task 3 on thread 11 is pt-BR
    //     Culture of task 5 on thread 11 is pt-BR
    //     Culture of task 6 on thread 11 is pt-BR
    //     Culture of task 4 on thread 10 is pt-BR
    
    Imports System.Globalization
    Imports System.Threading
    
    Module Example1
        Public Sub S1()
            Dim tasks As New List(Of Task)
            Console.WriteLine("The current culture is {0}",
                            Thread.CurrentThread.CurrentCulture.Name)
            Thread.CurrentThread.CurrentCulture = New CultureInfo("pt-BR")
            ' Change the current culture to Portuguese (Brazil).
            Console.WriteLine("Current culture changed to {0}",
                            Thread.CurrentThread.CurrentCulture.Name)
            Console.WriteLine("Application thread is thread {0}",
                            Thread.CurrentThread.ManagedThreadId)
            ' Launch six tasks and display their current culture.
            For ctr As Integer = 0 To 5
                tasks.Add(Task.Run(Sub()
                                       Console.WriteLine("Culture of task {0} on thread {1} is {2}",
                                                     Task.CurrentId,
                                                     Thread.CurrentThread.ManagedThreadId,
                                                     Thread.CurrentThread.CurrentCulture.Name)
                                   End Sub))
            Next
            Task.WaitAll(tasks.ToArray())
        End Sub
    End Module
    ' The example displays output like the following:
    '     The current culture is en-US
    '     Current culture changed to pt-BR
    '     Application thread is thread 9
    '     Culture of task 2 on thread 11 is pt-BR
    '     Culture of task 1 on thread 10 is pt-BR
    '     Culture of task 3 on thread 11 is pt-BR
    '     Culture of task 5 on thread 11 is pt-BR
    '     Culture of task 6 on thread 11 is pt-BR
    '     Culture of task 4 on thread 10 is pt-BR
    

    Pour plus d’informations, consultez Les opérations asynchrones basées sur la culture et les tâches.

  • En appelant la GetUserDefaultLocaleName fonction sur Windows ou la fonction à partir de l’ICUuloc_getDefault, qui appelle actuellement la fonction POSIX setlocale avec la catégorie LC_MESSAGES, sur les systèmes de type Unix.

Notez que si vous définissez une culture spécifique différente de la culture installée par le système ou de la culture préférée de l’utilisateur et que votre application démarre plusieurs threads, la culture actuelle de ces threads est la culture retournée par la GetUserDefaultLocaleName fonction, sauf si vous attribuez une culture à la DefaultThreadCurrentCulture propriété dans le domaine d’application dans lequel le thread s’exécute.

Pour plus d’informations sur la façon dont la culture d’un thread est déterminée, consultez la section « Culture et threads » dans la CultureInfo page de référence.

Obtenir la culture actuelle

La CultureInfo.CurrentCulture propriété est un paramètre par thread ; autrement dit, chaque thread peut avoir sa propre culture. Vous obtenez la culture du thread actuel en récupérant la valeur de la CultureInfo.CurrentCulture propriété, comme l’illustre l’exemple suivant.

using System;
using System.Globalization;

public class Example5
{
   public static void Main()
   {
      CultureInfo culture = CultureInfo.CurrentCulture;
      Console.WriteLine("The current culture is {0} [{1}]",
                        culture.NativeName, culture.Name);
   }
}
// The example displays output like the following:
//       The current culture is English (United States) [en-US]
Imports System.Globalization

Module Example3
    Public Sub S1()
        Dim culture As CultureInfo = CultureInfo.CurrentCulture
        Console.WriteLine("The current culture is {0} [{1}]",
                        culture.NativeName, culture.Name)
    End Sub
End Module
' The example displays output like the following:
'     The current culture is English (United States) [en-US]

Définir explicitement la propriété CurrentCulture

Pour modifier la culture utilisée par un thread existant, vous définissez la CultureInfo.CurrentCulture propriété sur la nouvelle culture. Si vous modifiez explicitement la culture d’un thread de cette façon, cette modification persiste si le thread traverse les limites du domaine d’application. L’exemple suivant modifie la culture actuelle du thread en néerlandais (Pays-Bas). Il montre également que, lorsque le thread actuel franchit les limites du domaine d’application, sa culture actuelle reste modifiée.

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

public class Info11 : MarshalByRefObject
{
    public void ShowCurrentCulture()
    {
        Console.WriteLine("Culture of {0} in application domain {1}: {2}",
                          Thread.CurrentThread.Name,
                          AppDomain.CurrentDomain.FriendlyName,
                          CultureInfo.CurrentCulture.Name);
    }
}

public class Example11
{
    public static void Main()
    {
        Info11 inf = new Info11();
        // Set the current culture to Dutch (Netherlands).
        Thread.CurrentThread.Name = "MainThread";
        CultureInfo.CurrentCulture = CultureInfo.CreateSpecificCulture("nl-NL");
        inf.ShowCurrentCulture();

        // Create a new application domain.
        AppDomain ad = AppDomain.CreateDomain("Domain2");
        Info11 inf2 = (Info11)ad.CreateInstanceAndUnwrap(typeof(Info11).Assembly.FullName, "Info11");
        inf2.ShowCurrentCulture();
    }
}
// The example displays the following output:
//       Culture of MainThread in application domain ChangeCulture1.exe: nl-NL
//       Culture of MainThread in application domain Domain2: nl-NL
Imports System.Globalization
Imports System.Threading

Public Class Info : Inherits MarshalByRefObject
   Public Sub ShowCurrentCulture()
      Console.WriteLine("Culture of {0} in application domain {1}: {2}",
                        Thread.CurrentThread.Name,
                        AppDomain.CurrentDomain.FriendlyName,
                        CultureInfo.CurrentCulture.Name)
   End Sub
End Class

Module Example2
    Public Sub S1()
        Dim inf As New Info()
        ' Set the current culture to Dutch (Netherlands).
        Thread.CurrentThread.Name = "MainThread"
        CultureInfo.CurrentCulture = CultureInfo.CreateSpecificCulture("nl-NL")
        inf.ShowCurrentCulture()

        ' Create a new application domain.
        Dim ad As AppDomain = AppDomain.CreateDomain("Domain2")
        Dim inf2 As Info = CType(ad.CreateInstanceAndUnwrap(GetType(Info).Assembly.FullName, "Info"),
                          Info)
        inf2.ShowCurrentCulture()
    End Sub
End Module
' This example displays the following output:
'       Culture of MainThread in application domain Example.exe: nl-NL
'       Culture of MainThread in application domain Domain2: nl-NL

Remarque

La modification de la culture à l’aide de la CultureInfo.CurrentCulture propriété nécessite une SecurityPermission autorisation avec le jeu de ControlThread valeurs. La manipulation de threads est dangereuse en raison de l’état de sécurité associé aux threads. Par conséquent, cette autorisation doit être accordée uniquement au code fiable, puis uniquement si nécessaire. Vous ne pouvez pas modifier la culture des threads dans du code semi-approuvé.

À compter de .NET Framework 4, vous pouvez modifier explicitement la culture de thread actuelle en une culture spécifique (par exemple, Français (Canada)) ou une culture neutre (par exemple, Français). Lorsqu’un CultureInfo objet représente une culture neutre, les valeurs des CultureInfo propriétés telles que Calendar, , CompareInfo, DateTimeFormat, NumberFormatet TextInfo reflètent la culture spécifique associée à la culture neutre. Par exemple, la culture dominante pour la culture neutre anglaise est l’anglais (États-Unis) ; la culture dominante pour la culture allemande est allemande (Allemagne). L’exemple suivant illustre la différence de mise en forme lorsque la culture actuelle est définie sur une culture spécifique, Français (Canada) et une culture neutre, Français.

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

public class Example12
{
   public static void Main()
   {
      double value = 1634.92;
      CultureInfo.CurrentCulture = new CultureInfo("fr-CA");
      Console.WriteLine("Current Culture: {0}",
                        CultureInfo.CurrentCulture.Name);
      Console.WriteLine("{0:C2}\n", value);

      Thread.CurrentThread.CurrentCulture = new CultureInfo("fr");
      Console.WriteLine("Current Culture: {0}",
                        CultureInfo.CurrentCulture.Name);
      Console.WriteLine("{0:C2}", value);
   }
}
// The example displays the following output:
//       Current Culture: fr-CA
//       1 634,92 $
//
//       Current Culture: fr
//       1 634,92 €
Imports System.Globalization
Imports System.Threading

Module Example4
    Public Sub S1()
        Dim value As Double = 1634.92
        CultureInfo.CurrentCulture = New CultureInfo("fr-CA")
        Console.WriteLine("Current Culture: {0}",
                        CultureInfo.CurrentCulture.Name)
        Console.WriteLine("{0:C2}", value)
        Console.WriteLine()

        Thread.CurrentThread.CurrentCulture = New CultureInfo("fr")
        Console.WriteLine("Current Culture: {0}",
                        CultureInfo.CurrentCulture.Name)
        Console.WriteLine("{0:C2}", value)
    End Sub
End Module
' The example displays the following output:
'       Current Culture: fr-CA
'       1 634,92 $
'       
'       Current Culture: fr
'       1 634,92 €

Vous pouvez également utiliser la CultureInfo.CurrentCulture propriété avec la HttpRequest.UserLanguages propriété pour définir la CurrentCulture propriété d’une application ASP.NET sur la culture préférée de l’utilisateur, comme l’illustre l’exemple suivant.

CultureInfo.CurrentCulture = CultureInfo.CreateSpecificCulture(Request13.UserLanguages[0]);
Thread.CurrentThread.CurrentCulture = CultureInfo.CreateSpecificCulture(Request.UserLanguages(0))

La culture et l’utilisateur actuels remplacent

Windows permet aux utilisateurs de remplacer les valeurs de propriété standard de l’objet CultureInfo et de ses objets associés à l’aide des options régionales et linguistiques dans Panneau de configuration. L’objet CultureInfo retourné par la CurrentCulture propriété reflète les remplacements de ces utilisateurs dans les cas suivants :

  • Si la culture de thread actuelle est définie implicitement par la fonction Windows GetUserDefaultLocaleName .

  • Si la culture de thread actuelle définie par la DefaultThreadCurrentCulture propriété correspond à la culture système Windows actuelle.

  • Si la culture de thread actuelle est définie explicitement sur une culture retournée par la CreateSpecificCulture méthode, et que cette culture correspond à la culture système Windows actuelle.

  • Si la culture de thread actuelle est définie explicitement sur une culture instanciée par le CultureInfo(String) constructeur, et que cette culture correspond à la culture système Windows actuelle.

Dans certains cas, en particulier pour les applications serveur, la définition de la culture actuelle sur un CultureInfo objet qui reflète les remplacements utilisateur peut être indésirable. Au lieu de cela, vous pouvez définir la culture actuelle sur un CultureInfo objet qui ne reflète pas les remplacements utilisateur de la manière suivante :

La culture actuelle et les applications UWP

Dans les applications plateforme Windows universelle (UWP), la CurrentCulture propriété est en lecture-écriture, tout comme dans les applications .NET Framework et .NET Core. Vous pouvez l’utiliser à la fois pour obtenir et définir la culture actuelle. Toutefois, les applications UWP ne font pas la distinction entre la culture actuelle et la culture actuelle de l’interface utilisateur. Les propriétés CurrentCulture et CurrentUICulture mappées à la première valeur de la collection Windows.ApplicationModel.Resources.Core.ResourceManager.DefaultContext.Languages.

Dans les applications .NET Framework et .NET Core, la culture actuelle est un paramètre par thread et la CurrentCulture propriété reflète la culture du thread actuel uniquement. Dans les applications UWP, la culture actuelle est mappée à la propriété Windows.ApplicationModel.Resources.Core.ResourceManager.DefaultContext.Languages , qui est un paramètre global. La définition de la CurrentCulture propriété modifie la culture de l’ensemble de l’application ; la culture ne peut pas être définie sur une base par thread.