[解決済み] C言語でnanとinfはどのように使うのですか?
質問
エラーが発生した場合、nanまたはinfを返すことができる数値メソッドを持っています。テスト目的で、状況が正しく処理されていることを確認するために、一時的にnanまたはinfを返すように強制したいと思います。信頼できる コンパイラーに依存しない C で nan と inf の値を作成する信頼できる、コンパイラーに依存しない方法はありますか?
10分ほどググってみたところ、コンパイラに依存した解決策しか見つかりませんでした。
どのように解決するのですか?
実装に備わっているかどうかをテストすることができます。
#include <math.h>
#ifdef NAN
/* NAN is supported */
#endif
#ifdef INFINITY
/* INFINITY is supported */
#endif
の存在は
INFINITY
の存在は C99 (または少なくとも最新のドラフト) で保証されており、 "は正または符号なしを表す float 型の定数表現に展開されます。
無限大を表す float 型の定数式に展開されます (利用可能な場合)、さもなければ翻訳時にオーバーフローする float 型の正の定数に展開されます。
NAN
は定義されていてもいなくてもよく、実装がfloat型のquiet NaNをサポートしている場合のみ、"が定義されます。これは、静かなNaNを表すfloat型の定数式に展開されます."。
浮動小数点値を比較している場合、および行うことに注意してください。
a = NAN;
でも
a == NAN;
が偽であることを確認します。 NaNをチェックする方法の1つは、次のようになります。
#include <math.h>
if (isnan(a)) { ... }
もできます。
a != a
をテストするために
a
がNaNであるかどうかをテストする。
また
isfinite()
,
isinf()
,
isnormal()
そして
signbit()
のマクロは
math.h
を C99 で使用することができます。
C99 ではまた
nan
の関数もあります。
#include <math.h>
double nan(const char *tagp);
float nanf(const char *tagp);
long double nanl(const char *tagp);
(参考:N1256)となります。
関連
-
C 構造体定義エラー: '['トークンの前に一次式があることが予想される
-
コンパイルエラー:可変長オブジェクトが初期化されていない可能性があります。
-
[解決済み] SQLiteのINSERT/per-secondのパフォーマンスを向上させる
-
[解決済み] 1ビットのセット、クリア、トグルはどのように行うのですか?
-
[解決済み] NaN値をチェックするにはどうすればよいですか?
-
[解決済み] JavaScriptで整数の除算を行い、余りを別途取得する方法は?
-
[解決済み] Pandas DataFrameの特定の列の値がNaNである行を削除する方法
-
[解決済み] Pandas DataFrameの値がNaNであるかどうかを確認する方法
-
[解決済み] JavaScriptで数値がNaNであることを確認するにはどうすればよいですか?
-
[解決済み】高放射能環境下で使用するアプリケーションのコンパイルについて
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
_CRT_SECURE_NO_WARNINGS エラーメッセージ、解決方法
-
ポインタ定数および定数ポインタ
-
[解決済み] PTHREAD_MUTEX_INITIALIZER vs pthread_mutex_init ( &mutex, param )
-
[解決済み] munmap_chunk(): 無効なポインタ
-
[解決済み] 配列のすべてのメンバーを同じ値で初期化するには?
-
[解決済み] mallocとcallocの違い?
-
[解決済み] なぜsizeof(x++)はxをインクリメントしないのですか?
-
[解決済み] フリーは、どのように無料化を知っているのですか?
-
[解決済み] ストラクチャーとユニオンの違い
-
[解決済み] Pythonでnumpyを使わずに変数にNaNを代入する