std:: atof
From cppreference.net
|
헤더 파일에 정의됨
<cstdlib>
|
||
|
double
atof
(
const
char
*
str
)
;
|
||
str 이 가리키는 바이트 문자열에서 부동 소수점 값을 해석합니다.
함수는 ( std::isspace 에 의해 결정되는) 공백 문자들을 모두 버리고 첫 번째 비-공백 문자를 찾을 때까지 진행합니다. 그런 다음 유효한 부동 소수점 표현을 형성하기 위해 가능한 많은 문자들을 취하여 부동 소수점 값으로 변환합니다. 유효한 부동 소수점 값은 다음 중 하나일 수 있습니다:
- decimal floating-point expression. 다음과 같은 부분들로 구성됩니다:
-
- (선택사항) 양수 또는 음수 부호
- 소수점 문자를 선택적으로 포함할 수 있는 비어 있지 않은 십진수 시퀀스 (현재 C locale 에 의해 결정됨) (유효숫자 정의)
-
(선택사항)
e또는E뒤에 선택적인 마이너스 또는 플러스 부호와 비어 있지 않은 십진수 시퀀스가 옴 (밑수 10 에 대한 지수 정의)
|
(C++11부터) |
- 현재 설치된 C locale 에서 허용될 수 있는 다른 표현.
목차 |
매개변수
| str | - | 해석할 null로 종료되는 바이트 문자열을 가리키는 포인터 |
반환값
double 값에 해당하는 내용이 str 에 있을 경우 성공적으로 반환됩니다. 변환된 값이 반환 타입의 범위를 벗어나면 반환 값은 정의되지 않습니다. 변환이 수행될 수 없는 경우, 0.0 이 반환됩니다.
예제
이 코드 실행
#include <cstdlib> #include <iostream> int main() { std::cout << std::atof("0.0000000123") << '\n' << std::atof("0.012") << '\n' << std::atof("15e16") << '\n' << std::atof("-0x1afp-2") << '\n' << std::atof("inF") << '\n' << std::atof("Nan") << '\n' << std::atof("invalid") << '\n'; }
출력:
1.23e-08 0.012 1.5e+17 -107.75 inf nan 0
참고 항목
|
(C++11)
(C++11)
(C++11)
|
문자열을 부동 소수점 값으로 변환
(함수) |
|
바이트 문자열을 부동 소수점 값으로 변환
(함수) |
|
|
(C++17)
|
문자 시퀀스를 정수 또는 부동 소수점 값으로 변환
(함수) |
|
(C++11)
|
바이트 문자열을 정수 값으로 변환
(함수) |
|
C 문서
for
atof
|
|