C言語関数:atof





C言語のページでは、次の内容を解説しております。
C言語の入門講座  C言語の文法を中心に、基本的な関数などの解説をしています。
C言語ケーススタディ  C言語での実践的なプログラミングについて解説をしています。
C言語の関数リファレンス  C言語で用意されている関数を解説しています。
C言語で3次元動画プログラム  C言語で3次元タートルグラフィックを使用した3次元の動画プログラムの作成例です。
C言語の検定試験  C言語の文法に関する検定試験を実施することができます。
C言語でゲーム作成  C言語を使用したゲームの作り方を解説したページも用意しております。



2014年10月より個人の方を対象に、Study C無料提供を開始しました。
C言語を勉強中の方は、学習・教育に最適なC言語インタープリタのStudy Cを使ってみてください(個人の方は無料です)。
大学・高専・高校などの教育機関での採用実績も多数あるロングセラー商品Study Cが、個人向けに無料提供を始めました。
インタープリタの手軽さに加え、ゲームや3Dタートルグラフィックで楽しく勉強したりと、C言語の学習を協力にサポートします。
ブロック崩しゲーム 3Dツリー クリスマスツリー
また、このようなボタンの用意されているページでは、掲載しているプログラムをStudy Cに直接ロードし実行したりすることができます。
Study Cにロードする Study Cにロードし編集する Study Cにロードし実行する
Study C無料利用についての詳細は、このページを参照してください。




■atof
文字列/浮動小数点変換

【分類】
文字列関数

【書式】
double atof(const char *s);

【パラメータの型と説明】

パラメータ説明
const char *s変換する文字列

【機能説明】
strの文字列をdouble型数値に変換し、その値を返します。
文字列には、符号/数字/小数点/指数部のeまたはEを使用することができます。
数字の前後にある空白は無視されます。
有効でない文字があった場合、それ以降は変換を行いません。

Study Cを使用している場合は、下記のようにコマンドラインから実行(exprコマンドを使用)して動作を確認することができます。

C:\StudyC\MyProg>expr atof("   123.45")
<double>123.45

C:\StudyC\MyProg>expr atof("-1.2345")
<double>-1.2345

C:\StudyC\MyProg>expr atof("1.2345e4")
<double>12345

C:\StudyC\MyProg>expr atof("-12345e-4")
<double>-1.2345

C:\StudyC\MyProg>expr atof("12.345abc")
<double>12.345

C:\StudyC\MyProg>expr atof("abc")
<double>0

1番目は正の実数123.45と変換されます(先頭の空白は無視されます)。
2番目は負の実数-1.2345と変換されます。
3番目は指数部が指定(10の4乗)されており12345と変換されます。
4番目は負の実数で指数部が指定(10の-4乗)されており-1.2345と変換されます。
5番目は無効な文字列「abc」を含んでいるので、その直前までが変換対象となります。
6番目は先頭が数字を構成する文字列でないので0を返します。

通常のコンパイラを使用する場合の使用例は下記になります(もちろんStudy CでもOKです)。

#include <stdio.h>

main()
{
        printf("%f\n", atof("   123.45"));
        printf("%f\n", atof("-1.2345"));
        printf("%f\n", atof("1.2345e4"));
        printf("%f\n", atof("-12345e-4"));
        printf("%f\n", atof("12.345abc"));
        printf("%f\n", atof("abc"));
}

実行結果は以下になります。


123.45
-1.2345
12345
-1.2345
12.345
0

atoi()関数で解説しましたが、atof()関数はエラー処理が無いので仕事でプログラムを作るようなときにはほとんど使用されません。 エラーチェックをしっかりと行う場合は、strtod()などの関数を使用します。

int型のatoi()、long型のatol()に対してdouble型を返すのにatod()でないのが不思議です。 creat()関数がcreate()で無いのと同じように深い意味はないと思います。

【参照関数】
atoi
atol
strtod
strtol
strtoul