Remarque
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
Remarque
Cet article fournit des remarques supplémentaires à la documentation de référence de cette API.
L’objet CultureInfo retourné par la propriété CurrentCulture 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 de toujours utiliser la propriété CultureInfo.CurrentCulture 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 qui effectue une opération asynchrone basée sur des tâches, sa culture est déterminée par celle 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 {Thread.CurrentThread.CurrentCulture.Name}"); Thread.CurrentThread.CurrentCulture = new CultureInfo("pt-BR"); // Change the current culture to Portuguese (Brazil). Console.WriteLine($"Current culture changed to {Thread.CurrentThread.CurrentCulture.Name}"); Console.WriteLine($"Application thread is thread {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 {Task.CurrentId} on thread {Thread.CurrentThread.ManagedThreadId} is {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-BRImports 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-BRPour plus d’informations, consultez Les opérations asynchrones basées sur la culture et les tâches.
En appelant la fonction
GetUserDefaultLocaleNamesur Windows ou la fonctionuloc_getDefaultà partir de ICU, qui appelle actuellement la fonction POSIXsetlocaleavec la catégorieLC_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. Pour obtenir la culture actuelle du thread, il faut récupérer la valeur de la propriété CultureInfo.CurrentCulture, comme le montre 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 {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. Dans l’exemple suivant la culture actuelle du thread change pour le 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 {Thread.CurrentThread.Name} in application domain {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
Le changement de la culture à l’aide de la propriété CultureInfo.CurrentCulture nécessite une autorisation SecurityPermission avec la valeur ControlThread définie. 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 changer la culture du thread 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çaise (Canada)) ou une culture neutre (par exemple, française). 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çaise (Canada) et une culture neutre, française.
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: {CultureInfo.CurrentCulture.Name}");
Console.WriteLine($"{value:C2}\n");
Thread.CurrentThread.CurrentCulture = new CultureInfo("fr");
Console.WriteLine($"Current Culture: {CultureInfo.CurrentCulture.Name}");
Console.WriteLine($"{value:C2}");
}
}
// 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 actuelle et les remplacements de l’utilisateur
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 le Panneau de configuration. L’objet CultureInfo retourné par la CurrentCulture propriété reflète ces remplacements par les 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 actuelle du thread est définie explicitement sur une culture retournée par la méthode CreateSpecificCulture, et que cette culture correspond à la culture système Windows actuelle.
Si la culture actuelle du thread est définie explicitement sur une culture instanciée par le constructeur CultureInfo(String), et que cette culture correspond à la culture système Windows actuelle.
Dans certains cas, en particulier pour les applications serveur, définir la culture actuelle sur un objet CultureInfo qui reflète les modifications utilisateur peut être indésirable. Au lieu de cela, vous pouvez définir la culture actuelle sur un objet CultureInfo qui ne reflète pas les modifications de l'utilisateur de la manière suivante :
En appelant le constructeur CultureInfo(String, Boolean) avec une valeur de
falsepour l’argumentuseUserOverride.En appelant la GetCultureInfo méthode, qui retourne un objet en lecture seule CultureInfo mis en cache.
La culture actuelle et les applications UWP
Dans les applications de la plateforme Windows universelle (UWP), la propriété CurrentCulture est en lecture-écriture, comme dans les applications .NET Framework et .NET Core. Vous pouvez l’utiliser tant pour obtenir que pour 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 correspondent à 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.