C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.94699 の関連記事表示

<< 0 >>
■94699  NaNやInifinityのバイナリデータ
□投稿者/ hori -(2020/05/06(Wed) 23:02:29)

    分類:[.NET 全般] 

    以前から疑問なのですが、
    Single.NaNやSingle.PositiveInfinity
    Double.NaNやDouble.PositiveInfinity
    というような値がありますが、
    これをバイナリファイルとして出力すると、どういう値として保存されますか?
親記事 /過去ログ164より / 関連記事表示
削除チェック/

■94700  Re[1]: NaNやInifinityのバイナリデータ
□投稿者/ キングダム -(2020/05/07(Thu) 00:07:59)
記事No.94699 のレス /過去ログ164より / 関連記事表示
削除チェック/

■94701  Re[2]: NaNやInifinityのバイナリデータ
□投稿者/ Hongliang -(2020/05/07(Thu) 03:56:14)
    C#のdouble/floatはSystem.Double/System.Singleのエイリアスであり、この2つの型はいずれもIEEE 754に準拠することになっています。
    https://docs.microsoft.com/ja-jp/dotnet/api/system.double?view=netframework-4.8
    https://docs.microsoft.com/ja-jp/dotnet/api/system.single?view=netframework-4.8

    IEEE 754においてはビット表現が規定されています。以下の「交換形式」のところ。
    https://ja.wikipedia.org/wiki/IEEE_754
    それによると無限大及びNaNのビット表現は、
    符号部:0または1(無限大の場合は0と1で別の値になるが、NaNの場合は別の値ではない)
    指数部:全ビット1
    仮数部:無限大では0、NaNでは0以外
    ということになってますね。
    無限大の場合は正負でそれぞれ1つの表現しかできませんが、NaNの場合は複数の表現が可能です。
    どの表現になるかはCPUとNaNの導出方法次第ということになるでしょうかね。
記事No.94699 のレス /過去ログ164より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -