Namespaces
Variants

std:: strtol, std:: strtoll

From cppreference.net
헤더 파일에 정의됨 <cstdlib>
long strtol ( const char * str, char ** str_end, int base ) ;
(1)
long long strtoll ( const char * str, char ** str_end, int base ) ;
(2) (C++11 이후)

str 이 가리키는 바이트 문자열에서 정수 값을 해석합니다.

첫 번째 비-공백 문자를 찾을 때까지 (즉, std::isspace 를 호출하여 식별되는) 모든 공백 문자들을 버린 다음, 유효한 base-n (여기서 n= base ) 정수 표현을 형성할 수 있는 최대한의 문자들을 취하여 정수 값으로 변환합니다. 유효한 정수 값은 다음 부분들로 구성됩니다:

  • (선택 사항) 양수 또는 음수 부호
  • (선택 사항) 접두사 ( 0 ) - 8진법 기수 표시 (기수가 8 또는 0 인 경우에만 적용)
  • (선택 사항) 접두사 ( 0x 또는 0X ) - 16진법 기수 표시 (기수가 16 또는 0 인 경우에만 적용)
  • 숫자 시퀀스

유효한 base 값의 집합은 {0, 2, 3, ..., 36} 입니다. base- 2 정수에 대한 유효한 숫자 집합은 {0, 1} , base- 3 정수에 대한 유효한 숫자 집합은 {0, 1, 2} 입니다. 10 보다 큰 base의 경우, 유효한 숫자에는 알파벳 문자가 포함되며, base- 11 정수에 대한 Aa 부터 base- 36 정수에 대한 Zz 까지입니다. 문자들의 대소문자는 무시됩니다.

현재 설치된 C locale 에서 추가 숫자 형식을 허용할 수 있습니다.

base 의 값이 0 인 경우, 숫자 진법은 자동으로 감지됩니다: 접두사가 0 이면 8진법, 접두사가 0x 또는 0X 이면 16진법, 그렇지 않으면 10진법입니다.

마이너스 기호가 입력 시퀀스의 일부였다면, 숫자 시퀀스로부터 계산된 숫자 값은 결과 타입에서 단항 마이너스 연산자에 의해 부정된 것처럼 처리됩니다.

이 함수는 str_end 가 가리키는 포인터를 해석된 마지막 문자 다음 문자를 가리키도록 설정합니다. 만약 str_end 가 널 포인터인 경우, 이는 무시됩니다.

만약 str 이 비어 있거나 예상된 형식을 갖고 있지 않으면, 변환이 수행되지 않으며 (만약 str_end 가 null 포인터가 아닌 경우) str 의 값이 str_end 가 가리키는 객체에 저장됩니다.

목차

매개변수

str - 해석할 null 종료 바이트 문자열에 대한 포인터
str_end - 문자에 대한 포인터의 포인터
base - base 해석된 정수 값의 기수

반환값

  • 성공 시, str 의 내용에 해당하는 정수 값이 반환됩니다.
  • 변환된 값이 해당 반환 타입의 범위를 벗어나는 경우, 범위 오류가 발생하며 ( errno ERANGE 로 설정) LONG_MAX , LONG_MIN , LLONG_MAX 또는 LLONG_MIN 이 반환됩니다.
  • 변환을 수행할 수 없는 경우, 0 이 반환됩니다.

예제

#include <cerrno>
#include <cstdlib>
#include <iomanip>
#include <iostream>
#include <string>
int main()
{
    const char* p = "10 200000000000000000000000000000 30 -40";
    std::cout << "Parsing " << std::quoted(p) << ":\n";
    for (;;)
    {
        // errno는 라이브러리 함수 호출 시 오류 발생 여부와 관계없이 0이 아닌 값으로 설정될 수 있으므로,
        // strtol에 의해 설정된 오류를 확인하려면 초기화되어야 함
        errno = 0;
        char* p_end{};
        const long i = std::strtol(p, &p_end, 10);
        if (p == p_end)
            break;
        const bool range_error = errno == ERANGE;
        const std::string extracted(p, p_end - p);
        p = p_end;
        std::cout << "Extracted " << std::quoted(extracted)
                  << ", strtol returned " << i << '.';
        if (range_error)
            std::cout << "\n  Range error occurred.";
        std::cout << '\n';
    }
}

가능한 출력:

Parsing "10 200000000000000000000000000000 30 -40":
Extracted "10", strtol returned 10.
Extracted " 200000000000000000000000000000", strtol returned 9223372036854775807.
  Range error occurred.
Extracted " 30", strtol returned 30.
Extracted " -40", strtol returned -40.

참고 항목

(C++11) (C++11) (C++11)
문자열을 부호 있는 정수로 변환
(함수)
바이트 문자열을 부호 없는 정수 값으로 변환
(함수)
(C++11) (C++11)
바이트 문자열을 std::intmax_t 또는 std::uintmax_t 로 변환
(함수)
와이드 문자열을 정수 값으로 변환
(함수)
바이트 문자열을 부동 소수점 값으로 변환
(함수)
(C++17)
문자 시퀀스를 정수 또는 부동 소수점 값으로 변환
(함수)
바이트 문자열을 정수 값으로 변환
(함수)
C 문서 for strtol , strtoll