我不明白以下 C 转换函数是如何工作的(以及为什么要这样写);我相当肯定原作者知道他在做什么:
typedef union TValue {
uint64_t u64;
double n;
struct {
uint32_t lo; /* Lower 32 bits of number. */
uint32_t hi; /* Upper 32 bits of number. */
} u32;
[...]
} TValue;
static int32_t num2bit(double n)
{
TValue o;
o.n = n + 6755399441055744.0; /* 2^52 + 2^51 */
return (int32_t)o.u32.lo;
}
static uint64_t num2u64(double n)
{
#ifdef _MSC_VER
if (n >= 9223372036854775808.0) /* They think it's a feature. */
return (uint64_t)(int64_t)(n - 18446744073709551616.0);
else
#endif
return (uint64_t)n;
}
- num2bit 实际上只是投入了
double
吗int32_t
?为什么要加法?为什么要这样写? - num2u64 中提到的这个“功能”是什么?(我相信 _MSC_VER 意味着它是微软 C 编译器的代码路径)。
请注意,并不总是使用这些函数(取决于 CPU 架构),这是针对 little-endian 的(我解决了一些预处理器宏以简化)。
在线浏览镜像的链接(代码来自LuaJIT项目):环绕头文件(或整个项目)。
每一个提示都值得赞赏。