Partilhar via


asctime_s, _wasctime_s

Converter uma estrutura de tempo de tm a uma cadeia de caracteres. Essas funções são versões de asctime, _wasctime com aprimoramentos de segurança conforme descrito em Recursos de segurança no CRT.

errno_t asctime_s( 
   char* buffer,
   size_t numberOfElements,
   const struct tm *_tm 
);
errno_t _wasctime_s( 
   wchar_t* buffer,
   size_t numberOfElements
   const struct tm *_tm 
);
template <size_t size>
errno_t asctime_s( 
   char (&buffer)[size],
   const struct tm *_tm 
); // C++ only
template <size_t size>
errno_t _wasctime_s( 
   wchar_t (&buffer)[size],
   const struct tm *_tm 
); // C++ only

Parâmetros

  • buffer
    [out] de ponteiro para um buffer para armazenar o resultado da cadeia de caracteres. Essa função assume um ponteiro para um local de memória válida com um tamanho especificado por numberOfElements.

  • numberOfElements
    [in] o tamanho do buffer usado para armazenar o resultado.

  • _tm
    [in] estrutura de data/hora. Essa função assume um ponteiro para um objeto válido de structtm .

Valor de retorno

Nulo se com êxito. Se houver uma falha, o manipulador inválido do parâmetro será chamado, conforme descrito em Validação do parâmetro. Se a execução for permitida continuar, o valor de retorno é um código de erro. Os códigos de erro são definidos em ERRNO.H. Para obter mais informações, consulte Constantes errno. Os códigos de erro retornados reais para cada condição de erro são mostrados na tabela a seguir.

Condições de erro

buffer

numberOfElements

tm

Return

Valor em buffer

NULL

Alguns

Alguns

EINVAL

Não modificados

NãoNULL (pontos para a memória válido)

0

Alguns

EINVAL

Não modificados

Não NULL

0< tamanhos < 26

Alguns

EINVAL

Cadeia de caracteres vazia

Não NULL

>= 26

NULL

EINVAL

Cadeia de caracteres vazia

Não NULL

>= 26

Estrutura de hora inválido ou fora dos valores de intervalo para componentes de hora

EINVAL

Cadeia de caracteres vazia

Dica

As condições de erro para wasctime_s são semelhantes a asctime_s com exceção do limite de tamanho é medido no word.

Comentários

A função de asctime converte uma hora armazenados como uma estrutura para uma cadeia de caracteres. O valor de _tm geralmente é obtido de uma chamada para gmtime ou a localtime. Ambas as funções podem ser usadas para preencher uma estrutura de tm , conforme definido em. TIME.H.

membro de timeptr

Valor

tm_hour

Hora desde meia-noite (0-23)

tm_isdst

Positivo se o horário de verão é aplicado; 0 se o horário de verão não for aplicado; negativo se o status do horário de verão é desconhecido. A biblioteca de tempo de execução C assumirá as regras dos Estados Unidos para implementar o cálculo de horário de verão (DST).

tm_mday

Dia do mês (1-31)

tm_min

Minutos depois da hora (0-59)

tm_mon

Mês (0-11; janeiro = 0)

tm_sec

Segundos após o minuto (0-59)

tm_wday

Dia da semana (0-6; Domingo = 0)

tm_yday

Dia do ano (0-365; 1º de janeiro = 0)

tm_year

Ano (o ano atual menos 1900)

A cadeia de caracteres convertida também é ajustada de acordo com as configurações de fuso horário local. Consulte time, _time32, _time64, _ftime, _ftime32, _ftime64, e as funções de localtime_s, _localtime32_s, _localtime64_s para obter informações sobre como configurar a hora local e a função de _tzset para obter mais informações sobre como configurar o ambiente de fuso horário e variáveis globais.

O resultado da cadeia de caracteres gerado por asctime_s contém exatamente 26 caracteres e tem o formato Wed Jan 02 02:03:55 1980\n\0. Um relógio de 24 horas é usado. Todos os campos têm uma largura constante. O caractere de nova linha e o caractere nulo ocupam as duas posições as mais recentes de cadeia de caracteres. O valor passado como o segundo parâmetro deve ser pelo menos este grande. Se for menos, um código de erro, EINVAL, será retornado.

_wasctime_s é uma versão de caracteres largos de asctime_s. Caso contrário, _wasctime_s e asctime_s, ao contrário, se comportam de forma idêntica.

Mapeamento de rotina de Genérico- texto

Rotina TCHAR.H

_UNICODE & _MBCS não definido

_MBCS definido

_UNICODE definido

_tasctime_s

asctime_s

asctime_s

_wasctime_s

No C++, o uso dessas funções é simplificado pelas sobrecargas de modelo; as sobrecargas podem interpretar o tamanho do buffer automaticamente, eliminando a necessidade de especificar um argumento de tamanho. Para obter mais informações, consulte Sobrecargas de modelo seguras.

Requisitos

Rotina

Cabeçalho necessário

asctime_s

<time.h>

_wasctime_s

<time.h ou> wchar.h <>

Segurança

Se o ponteiro de buffer não é NULL e não o ponteiro para um buffer válido, a função substituirá o que existir no local. Isso também pode levar a uma violação de acesso.

excesso de buffer pode ocorrer se o argumento de tamanho passado for maior que o tamanho real do buffer.

Exemplo

Esse programa coloca a hora do sistema em inteiro longo aclock, tradu-los na estrutura newtime e converte a cadeia de caracteres no formato de saída, usando a função de asctime_s .

// crt_asctime_s.c
#include <time.h>
#include <stdio.h>

struct tm newtime;
__time32_t aclock;

int main( void )
{
   char buffer[32];
   errno_t errNum;
   _time32( &aclock );   // Get time in seconds.
   _localtime32_s( &newtime, &aclock );   // Convert time to struct tm form.

   // Print local time as a string.

   errNum = asctime_s(buffer, 32, &newtime);
   if (errNum)
   {
       printf("Error code: %d", (int)errNum);
       return 1;
   }
   printf( "Current date and time: %s", buffer );
   return 0;
}
  

Equivalência do .NET Framework

Consulte também

Referência

Gerenciamento de tempo

ctime_s, _ctime32_s, _ctime64_s, _wctime_s, _wctime32_s, _wctime64_s

_ftime, _ftime32, _ftime64

gmtime_s, _gmtime32_s, _gmtime64_s

localtime_s, _localtime32_s, _localtime64_s

time, _time32, _time64

_tzset