Compartilhar via


_configthreadlocale

Configurar opções de localidade por thread.

int _configthreadlocale( int type );

Parâmetros

  • type
    Definir a opção.Uma das opções listadas na tabela a seguir.

Valor de retorno

O status anterior de localidade por segmentos (_DISABLE_PER_THREAD_LOCALE ou _ENABLE_PER_THREAD_LOCALE), ou -1 em caso de falha.

Comentários

A função de _configurethreadlocale é usada para controlar o uso de localidades com específicas.Use uma dessas opções para especificar ou determinar o status da localidade por thread:

  • _ENABLE_PER_THREAD_LOCALE
    Faça o segmento atual usar uma localidade com específica.Chamadas subsequentes a setlocale neste segmento afetam somente própria localidade de segmento.

  • _DISABLE_PER_THREAD_LOCALE
    Faça o segmento atual usar a localidade global.Chamadas subsequentes a setlocale neste segmento afetam outros segmentos usando a localidade global.

  • 0
    Recupera a configuração atual para este segmento específico.

Essas funções afetam o comportamento de setlocale, de _tsetlocale, de _wsetlocale, de _beginthread, e de_beginthreadex.Se outro método é usado para criar segmentos, as configurações de localidade não têm efeito nos segmentos.

Quando a localidade por segmentos é desativada, qualquer chamada subsequente a setlocale ou a _wsetlocale alterar a localidade de todos os segmentos.Quando a localidade por segmento estiver ativada, setlocale ou _wsetlocale afetam somente a localidade atual da thread.

Se você usar _configurethreadlocale para ativar uma localidade por segmento, recomendamos que você chama setlocale ou _wsetlocale para definir imediatamente mais tarde a localidade preferencial naquele segmento.

Se type não é um dos valores listados na tabela, essa função chama o manipulador de parâmetro inválido, como descrito em Validação de parâmetro.Se a execução é permitida continuar, define errno dessa função a EINVAL e retorna -1.

Requisitos

Rotina

Cabeçalho necessário

_configthreadlocale

<locale.h>

Exemplo

// crt_configthreadlocale.cpp
// 
// This program demonstrates the use of _configthreadlocale when
// using is two independent threads.
//

#include <locale.h>
#include <process.h>
#include <windows.h>
#include <stdio.h>
#include <time.h>

#define BUFF_SIZE 100

// Retrieve the date and time in the current
// locale's format.
int get_time(unsigned char* str)
{
    __time64_t  ltime;
    struct tm   thetime;

    // Retieve the time
    _time64(&ltime);
    _gmtime64_s(&thetime, &ltime);

    // Format the current time structure into a string
    // using %#x is the long date representation,
    // appropriate to the current locale
    if (!strftime((char *)str, BUFF_SIZE, "%#x", 
                  (const struct tm*)&thetime))
    {
        printf("strftime failed!\n");
        return -1;
    }
    return 0;
}

// This thread sets its locale to German
// and prints the time.
unsigned __stdcall SecondThreadFunc( void* pArguments )
{
    unsigned char str[BUFF_SIZE];

    // Set the thread code page
    _setmbcp(_MB_CP_ANSI)

    // Set the thread locale
    printf("The thread locale is now set to %s.\n",
           setlocale(LC_ALL, "German"));

    // Retrieve the time string from the helper function
    if (get_time(str) == 0)
    {
        printf("The time in German locale is: '%s'\n", str);
    }

    _endthreadex( 0 );
    return 0;
} 

// The main thread spawns a second thread (above) and then
// sets the locale to English and prints the time.
int main()
{ 
    HANDLE          hThread;
    unsigned        threadID;
    unsigned char   str[BUFF_SIZE];

    // Configure per-thread locale to cause all subsequently created 
    // threads to have their own locale.
    _configthreadlocale(_ENABLE_PER_THREAD_LOCALE);

    // Retrieve the time string from the helper function
    printf("The thread locale is now set to %s.\n",
           setlocale(LC_ALL, "English"));

    // Create the second thread.
    hThread = (HANDLE)_beginthreadex( NULL, 0, &SecondThreadFunc,
                                      NULL, 0, &threadID );

    if (get_time(str) == 0)
    {
        // Retrieve the time string from the helper function
        printf("The time in English locale is: '%s'\n\n", str);
    }

    // Wait for the created thread to finish.
    WaitForSingleObject( hThread, INFINITE );

    // Destroy the thread object.
    CloseHandle( hThread );
}
  
  
  
  

Equivalência do .NET Framework

Não aplicável. No entanto, consulte. Usando a propriedade CurrentCulture

Consulte também

Referência

setlocale, wsetlocale

_beginthread, beginthreadex

Localidade

Multithreading e localidades