私はWin XPで実行されているC++プログラムのためのバイトワイプルーチンを作成しようとしています。ダブルバイトする方法は?
int byteswap(int v) // This is good
{
return _byteswap_ulong(v);
}
double byteswap(double v) // This doesn't work for some values
{
union { // This trick is first used in Quake2 source I believe :D
__int64 i;
double d;
} conv;
conv.d = v;
conv.i = _byteswap_uint64(conv.i);
return conv.d;
}
とテストへの関数::
-76.789999999988126 -76.790000000017230 0.000000000029104 -30.499999999987718 -30.499999999994994 0.000000000007276 41.790000000014508 41.790000000029060 -0.000000000014552 90.330000000023560 90.330000000052664 -0.000000000029104を:これらの数字が一致しないガイド
void testit() {
double a, b, c;
CString str;
for (a = -100; a < 100; a += 0.01) {
b = byteswap(a);
c = byteswap(b);
if (a != c) {
str.Format("%15.15f %15.15f %15.15f", a, c, a - c);
}
}
}
私はこれは私が作ってみたものですのVisual Studio 2008でコンパイルしています
これは読んだ後です:
How do I convert between big-endian and little-endian values in C++?
(私は間違えてる場合を除き?)あなたは方法によって、二重に< <と>>を使用することはできません
正確クエイク2に発明された何を明確にもらえますか?確かに、同じ組合のフィールドとしてdoubleとint64を持つ考えはありませんか? –
申し訳ありません..私はQuake2のCを学んだので、私はそれが一番だとふりをするのが好きです:D私はそれを今どこにでも見ています。 – Darrell