atof
From cppreference.net
|
ヘッダーで定義
<stdlib.h>
|
||
|
double
atof
(
const
char
*
str
)
;
|
||
str が指すバイト文字列内の浮動小数点値を解釈します。
関数は( isspace によって判定される)空白文字を最初の非空白文字が見つかるまで破棄します。その後、有効な浮動小数点表現を形成するために可能な限り多くの文字を取り込み、それらを浮動小数点値に変換します。有効な浮動小数点値は以下のいずれかです:
- 10進浮動小数点式。以下の部分で構成されます:
-
- (オプション) プラスまたはマイナス記号
- 空でない10進数のシーケンス(現在のC locale で決定される)に、オプションで小数点文字を含む(仮数部を定義)
-
(オプション)
eまたはEの後に、オプションのマイナスまたはプラス記号と空でない10進数のシーケンスが続く(基数 10 の指数を定義)
|
(C99以降) |
- 現在インストールされているC ロケール で受け入れられる可能性のあるその他の式。
目次 |
パラメータ
| str | - | 解釈対象のヌル終了バイト文字列へのポインタ |
戻り値
double 値が、成功時に str の内容に対応します。変換された値が戻り値の型の範囲外の場合、戻り値は未定義です。変換が実行できない場合、 0.0 が返されます。
注記
この名前は「ASCII to float」を意味します。
例
このコードを実行
#include <stdio.h> #include <stdlib.h> int main(void) { printf("%g\n", atof(" -0.0000000123junk")); printf("%g\n", atof("0.012")); printf("%g\n", atof("15e16")); printf("%g\n", atof("-0x1afp-2")); printf("%g\n", atof("inF")); printf("%g\n", atof("Nan")); printf("%g\n", atof("1.0e+309")); // UB: doubleの範囲外 printf("%g\n", atof("0.0")); printf("%g\n", atof("junk")); // 変換を実行できません }
出力例:
-1.23e-08 0.012 1.5e+17 -107.75 inf nan inf 0 0
参考文献
- C23規格 (ISO/IEC 9899:2024):
-
- 7.22.1.1 atof関数 (p: TBD)
- C17規格 (ISO/IEC 9899:2018):
-
- 7.22.1.1 atof関数 (p: TBD)
- C11規格 (ISO/IEC 9899:2011):
-
- 7.22.1.1 atof関数 (p: 341)
- C99規格 (ISO/IEC 9899:1999):
-
- 7.20.1.1 atof関数 (p: 307)
- C89/C90標準 (ISO/IEC 9899:1990):
-
- 4.10.1.1 atof関数
関連項目
|
(C99)
(C99)
|
バイト文字列を浮動小数点値に変換する
(関数) |
|
C++ documentation
for
atof
|
|