Funzione CompareString (winnls.h)
Confronta due stringhe di caratteri, per le impostazioni locali specificate dall'identificatore.
Sintassi
int CompareString(
[in] LCID Locale,
[in] DWORD dwCmpFlags,
[in] LPCTSTR lpString1,
[in] int cchCount1,
[in] LPCTSTR lpString2,
[in] int cchCount2
);
Parametri
[in] Locale
Identificatore delle impostazioni locali usate per il confronto. È possibile usare la macro MAKELCID per creare un identificatore delle impostazioni locali o usare uno dei valori predefiniti seguenti.
- LOCALE_CUSTOM_DEFAULT
- LOCALE_CUSTOM_UI_DEFAULT
- LOCALE_CUSTOM_UNSPECIFIED
- LOCALE_INVARIANT
- LOCALE_SYSTEM_DEFAULT
- LOCALE_USER_DEFAULT
[in] dwCmpFlags
Flag che indicano come la funzione confronta le due stringhe. Per definizioni dettagliate, vedere il parametro dwCmpFlags di CompareStringEx.
[in] lpString1
Puntatore alla prima stringa da confrontare.
[in] cchCount1
Lunghezza della stringa indicata da lpString1, escluso il carattere null terminante. Questo valore rappresenta i byte per la versione ANSI della funzione e dei caratteri wide per la versione Unicode. L'applicazione può fornire un valore negativo se la stringa è terminata con null. In questo caso, la funzione determina automaticamente la lunghezza.
[in] lpString2
Puntatore alla seconda stringa da confrontare.
[in] cchCount2
Lunghezza della stringa indicata da lpString2, escluso il carattere null terminante. Questo valore rappresenta i byte per la versione ANSI della funzione e dei caratteri wide per la versione Unicode. L'applicazione può fornire un valore negativo se la stringa è terminata con null. In questo caso, la funzione determina automaticamente la lunghezza.
Valore restituito
Restituisce i valori descritti per CompareStringEx.
Commenti
Vedere Osservazioni per CompareStringEx.
Se l'applicazione chiama la versione ANSI di CompareString, la funzione converte i parametri tramite la tabella codici predefinita delle impostazioni locali fornite. Pertanto, un'applicazione non può mai usare CompareString per gestire il testo UTF-8.
Normalmente, per i confronti senza distinzione tra maiuscole e minuscole, CompareString esegue il mapping dei caratteri minuscoli "i" alla "I" maiuscola, anche quando le impostazioni locali sono turche o azerbaijani. Il flag NORM_LINGUISTIC_CASING sostituisce questo comportamento per il turco o l'Azerbaijani. Se questo flag viene specificato in combinazione con turco o Azerbaijani, LATIN SMALL LETTER DOTLESS I (U+0131) è la forma minuscola di LETTERA MAIUSCOLA LATINA I (U+0049) e LATIN SMALL LETTER I (U+0069) è la forma minuscola della LETTERA MAIUSCOLA I CON PUNTO SOPRA (U+0130).
A partire da Windows 8: la versione ANSI della funzione viene dichiarata in Winnls.h e la versione Unicode viene dichiarata in Stringapiset.h. Prima di Windows 8, entrambe le versioni sono state dichiarate in Winnls.h.
Requisiti
Requisito | Valore |
---|---|
Client minimo supportato | Windows 2000 Professional [solo app desktop] |
Server minimo supportato | Windows 2000 Server [solo app desktop] |
Piattaforma di destinazione | Windows |
Intestazione | winnls.h (includere Windows.h) |
Libreria | Kernel32.lib |
DLL | Kernel32.dll |
Vedere anche
Gestione dell'ordinamento nelle applicazioni
Supporto per la lingua nazionale
Funzioni di supporto del linguaggio nazionale
Considerazioni sulla sicurezza: funzionalità internazionali
Uso della normalizzazione Unicode per rappresentare stringhe