Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
Especifica que o runtime deve usar ordens de ordenação legadas ao realizar comparações de strings.
<configuração>
<tempo de execução>
<CompatSortNLSVersion>
Sintaxe
<CompatSortNLSVersion
enabled="4096"/>
Atributos e Elementos
As seções a seguir descrevem atributos, elementos filho e elementos pai.
Attributes
| Attribute | Description |
|---|---|
enabled |
Atributo obrigatório. Especifica o ID local cuja ordem de ordenação deve ser usada. |
Atributo ativado
| Valor | Description |
|---|---|
| 4096 | O ID local que representa uma ordem de ordenação alternativa. Neste caso, 4096 representa a ordem de ordenação do .NET Framework 3.5 e versões anteriores. |
Elementos Subordinados
Nenhum.
Elementos Principais
| Elemento | Description |
|---|---|
configuration |
O elemento raiz em cada arquivo de configuração usado pelo Common Language Runtime e aplicativos .NET Framework. |
runtime |
Contém informações sobre opções de inicialização de tempo de execução. |
Observações
Como as operações de comparação, ordenação e minúsculas de strings realizadas pela System.Globalization.CompareInfo classe no .NET Framework 4 cumprem o padrão Unicode 5.1, os resultados dos métodos de comparação de strings como String.Compare(String, String) e String.LastIndexOf(String) podem diferir das versões anteriores do .NET Framework. Se a sua aplicação depender do comportamento legado, pode restaurar as regras de comparação e ordenação de strings usadas no .NET Framework 3.5 e versões anteriores, incluindo o <CompatSortNLSVersion> elemento no ficheiro de configuração da sua aplicação.
Importante
Restaurar regras legadas de comparação e ordenação de strings também exige que a sort00001000.dll biblioteca de links dinâmicos esteja disponível no sistema local.
Também pode usar regras legadas de ordenação e comparação de cadeias num domínio de aplicação específico, passando a cadeia "NetFx40_Legacy20SortingBehavior" para o SetCompatibilitySwitches método ao criar o domínio de aplicação.
Example
O exemplo seguinte instancia dois String objetos e chama o String.Compare(String, String, StringComparison) método para os comparar, usando as convenções da cultura atual.
using System;
enum StringComparisonResult
{
precedes = -1,
equals = 0,
follows = 1,
};
public class Example
{
public static void Main()
{
string str1 = new string( new char[] {'\u0219', '\u021B', 'a' });
string str2 = "a";
Console.WriteLine("{0} {1} {2} in the sort order.",
str1,
(StringComparisonResult) String.Compare(str1, str2, StringComparison.CurrentCulture),
str2);
}
}
Enum StringComparisonResult As Integer
precedes = -1
equals = 0
follows = 1
End Enum
Module Example
Public Sub Main()
Dim str1 As String = ChrW(&h219) + ChrW(&h21B) + "a"
Dim str2 As String = "a"
Console.WriteLine("{0} {1} {2} in the sort order.", _
str1, _
CType(String.Compare(str1, str2, StringComparison.CurrentCulture), StringComparisonResult), _
str2)
End Sub
End Module
Quando executa o exemplo no .NET Framework 4, ele mostra o seguinte resultado:
sta follows a in the sort order.
Isto é completamente diferente do resultado que é mostrado quando executas o exemplo no .NET Framework 3.5:
sta equals a in the sort order.
No entanto, se adicionar o ficheiro de configuração seguinte ao diretório do exemplo e depois executar o exemplo no .NET Framework 4, a saída é idêntica à produzida pelo exemplo quando é executado no .NET Framework 3.5.
<?xml version ="1.0"?>
<configuration>
<runtime>
<CompatSortNLSVersion enabled="4096"/>
</runtime>
</configuration>