asctime
, _wasctime
Converter uma estrutura de hora tm
para uma cadeia de caracteres. Versões mais seguras dessas funções estão disponíveis; confira asctime_s
, _wasctime_s
.
Sintaxe
char *asctime(
const struct tm *timeptr
);
wchar_t *_wasctime(
const struct tm *timeptr
);
Parâmetros
timeptr
Estrutura de hora/data.
Valor retornado
asctime
retorna um ponteiro para o resultado de cadeia de caracteres; _wasctime
retorna um ponteiro para o resultado de cadeia de caracteres largos. Não há valor de retorno de erro.
Comentários
Versões mais seguras dessas funções estão disponíveis; confira asctime_s
, _wasctime_s
.
A função asctime
converte uma hora armazenada como uma estrutura para uma cadeia de caracteres. O timeptr
valor é normalmente obtido de uma chamada para gmtime
ou localtime
, que retornam um ponteiro para uma tm
estrutura, definida em TIME.H.
Membro do timeptr |
Valor |
---|---|
tm_hour |
Horas desde a meia-noite (0 a 23) |
tm_isdst |
Positivo se o horário de verão estiver em vigor; 0 se o horário de verão não estiver em vigor; negativo se o status do horário de verão for desconhecido. A biblioteca em tempo de execução C presume as regras dos Estados Unidos para implementar o cálculo de DST (horário de verão). |
tm_mday |
Dia do mês (1 a 31) |
tm_min |
Minutos após a hora (0 a 59) |
tm_mon |
Mês (0 a 11; janeiro = 0) |
tm_sec |
Segundos após o minuto (0 a 59) |
tm_wday |
Dia da semana (0 a 6; domingo = 0) |
tm_yday |
Dia do ano (0 a 365; 1º de janeiro = 0) |
tm_year |
Ano (ano atual menos 1900) |
Para obter informações sobre como configurar a hora local, consulte as time
funções , _ftime
e localtime
. Para obter informações sobre como definir o ambiente de fuso horário e as variáveis globais, consulte a _tzset
função.
O resultado da cadeia de caracteres produzido por asctime
contém exatamente 26 caracteres e tem o formato Wed Jan 2 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 últimas posições da cadeia de caracteres. asctime
usa um único buffer alocado estaticamente para armazenar a cadeia de caracteres de retornada. Cada chamada para essa função destrói o resultado da chamada anterior.
_wasctime
é uma versão de caractere largo de asctime
, e se comporta de forma idêntica a asctime
.
Essas funções validam seus parâmetros. Se timeptr
for um ponteiro nulo ou se contiver valores fora do intervalo, o manipulador de parâmetro inválido será invocado, conforme descrito em Validação de parâmetro. Se a execução puder continuar, a função retornará NULL
e definirá errno
como EINVAL
.
Por padrão, o estado global dessa função tem como escopo o aplicativo. Para alterar esse comportamento, confira Estado global no CRT.
Mapeamento de rotina de texto genérico
Rotina TCHAR.H |
_UNICODE e _MBCS não definidos |
_MBCS definido |
_UNICODE definido |
---|---|---|---|
_tasctime |
asctime |
asctime |
_wasctime |
Requisitos
Rotina | Cabeçalho necessário |
---|---|
asctime |
<time.h> |
_wasctime |
<time.h> ou <wchar.h> |
Exemplo
Este programa coloca a hora do sistema no inteiro aclock
longo, traduz-o na estrutura newtime
e, em seguida, converte-o em forma de string para saída usando a asctime
função.
// crt_asctime.c
// compile with: /W3
#include <time.h>
#include <stdio.h>
int main( void )
{
struct tm *newTime;
time_t szClock;
// Get time in seconds
time( &szClock );
// Convert time to struct tm form
newTime = localtime( &szClock );
// Print local time as a string.
printf_s( "Current date and time: %s", asctime( newTime ) ); // C4996
// Note: asctime is deprecated; consider using asctime_s instead
}
Current date and time: Sun Feb 3 11:38:58 2002
Confira também
Gerenciamento de tempo
ctime
, _ctime32
, _ctime64
, _wctime
, _wctime32
, , _wctime64
_ftime
, _ftime32
, _ftime64
gmtime
, _gmtime32
, _gmtime64
localtime
, _localtime32
, _localtime64
time
, _time32
, _time64
_tzset
asctime_s
, _wasctime_s