Compartilhar via


strtol, wcstol, _strtol_l, _wcstol_l

Converta seqüências de caracteres em um valor inteiro longo.

long strtol(
   const char *nptr,
   char **endptr,
   int base 
);
long wcstol(
   const wchar_t *nptr,
   wchar_t **endptr,
   int base 
);
long _strtol_l(
   const char *nptr,
   char **endptr,
   int base,
   _locale_t locale
);
long _wcstol_l(
   const wchar_t *nptr,
   wchar_t **endptr,
   int base,
   _locale_t locale
);

Parâmetros

  • nptr
    Seqüência terminada por caractere nulo para converter.

  • endptr
    Ponteiro para o caractere que interrompe a varredura.

  • base
    Número base a ser usado.

  • locale
    Código de idioma.

Valor de retorno

strtolRetorna o valor representado na seqüência de caracteres nptr, exceto quando a representação poderia causar um estouro de capacidade, que nesse caso retorna LONG_MAX ou LONG_MIN.strtolRetorna 0 se nenhuma conversão pode ser executada.wcstolRetorna valores analogamente para strtol.Para ambas as funções, errno for definido como ERANGE se ocorrer estouro positivo ou negativo.

Consulte _doserrno, errno, _sys_errlist e _sys_nerr para obter mais informações sobre estes e outros códigos de retorno.

Comentários

The strtol function converts nptr to a long.strtolInterrompe a leitura a seqüência de caracteres nptr no primeiro caractere que não reconhece como parte de um número.Isso pode ser o caractere nulo de terminação, ou pode ser o primeiro caractere numérico maior que ou igual a base.

wcstolé uma versão de caractere largo de strtol; sua nptr argumento é uma seqüência de caracteres largos.Essas funções se comportam exatamente caso contrário.

Mapeamentos de rotina de texto genérico

TCHAR.Rotina H

_ Unicode & _ MBCS do arquivo não definido

_ MBCS do arquivo definido

_ Unicode definido

_tcstol

strtol

strtol

wcstol

_tcstol_l

_strtol_l

_strtol_l

_wcstol_l

A localidade atual LC_NUMERIC categoria determina o reconhecimento do caractere fracionário nptr*;* para obter mais informações, consulte setlocale.As funções, sem a _l sufixo usam a localidade atual; _strtol_le _wcstol_l são idênticas às funções correspondentes sem a _l de sufixo, exceto que eles usam a localidade do passado em vez disso.Para obter mais informações, consulte Localidade.

Se endptr não é NULL, um ponteiro para o caractere que parou a verificação é armazenado no local apontado pelo endptr.Se nenhuma conversão pode ser realizada (não foi encontrado nenhum dígito válido ou uma base inválida foi especificada), o valor de nptr é armazenado no local apontado pelo endptr.

strtol espera nptr para apontar para uma seqüência de caracteres do seguinte formato:

[whitespace] [{+ | –}] [0 [{ x | X }]] [digits]

A whitespace pode consistir em caracteres de espaço e tabulação, que são ignorados; digitssão um ou mais dígitos decimais.O primeiro caractere que não cabe neste formulário pára a varredura.Se base está entre 2 e 36, e em seguida, ele é usado como a base do número.Se base é 0, os caracteres iniciais da seqüência de caracteres apontada por nptr são usados para determinar a base.Se o primeiro caractere é 0 e o segundo caractere não é 'x' ou 'X', a seqüência de caracteres é interpretada como um inteiro octal; Caso contrário, ele é interpretado como um número decimal.Se o primeiro caractere é '0' e o segundo é o caractere 'x' ou 'X', a seqüência de caracteres é interpretada como um inteiro hexadecimal.Se o primeiro caractere é ' 1' a ' 9', a seqüência de caracteres é interpretada como um número inteiro decimal.As letras 'a' a 'z' (ou 'A' a 'Z') é atribuída os valores de 10 a 35; apenas letras cujos valores atribuídos estão menos de base são permitidos.

Requisitos

Rotina

Cabeçalho necessário

strtol

<stdlib.h>

wcstol

<stdlib.h> ou <wchar.h>

_strtol_l

<stdlib.h>

Para obter informações adicionais de compatibilidade, consulte compatibilidade na introdução.

Exemplo

Consulte o exemplo para strtod.

Equivalência do .NET Framework

System::CONVERT::ToInt64

Consulte também

Referência

Conversão de Dados

Localidade

localeconv

setlocale, wsetlocale

Seqüência de funções de valor numérico

strtod, _strtod_l, wcstod, _wcstod_l

strtoul, _strtoul_l, wcstoul, _wcstoul_l

atof, _atof_l, _wtof, _wtof_l