[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 1001- 2ch.scのread.cgiへ]
Update time : 04/24 17:46 / Filesize : 290 KB / Number-of Response : 1031
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

スレ立てるまでもない質問はここで 144匹目



534 名前:デフォルトの名無しさん mailto:sage [2016/12/07(水) 22:13:13.11 ID:uezJiPW5.net]
質問です。

環境: VC++2015 x64


"符号なし64ビット整数"の変数に、最大値を設定してから "double" にキャストし、もとの型の"符号なし64ビット整数"に戻すと、値がざっくり半分となってしまいます。
この挙動は、CPUまたはコンパイラ的に、正しい挙動なのでしょうか?

(符号付き整数では、最上位ビットが符号を表すのは理解してますが、以下のコードが通らないのは、直感に反するかと思います)


#include <inttypes.h>

int main(void)
{

uint64_t a = 0xFFFFFFFFFFFFFFFF; // a == 18446744073709551615

double b = (double)a; // b == 1.8446744073709552e+19
uint64_t c = (uint64_t)b; // c == 9223372036854775808 ???

ASSERT(a == b); // ok
ASSERT(b == c); // failed ???

}






[ 続きを読む ] / [ 携帯版 ]

全部読む 前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<290KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef