PostgreSQL 编译开关disable-float4-byval 与disable-fl...
发布时间:2020-12-13 17:37:38 所属栏目:百科 来源:网络整理
导读:./configure --help我们能看到两个编译开关: --disable-float4-byval disable float4 passed by value --disable-float8-byval disable float8 passed by value 所有涉及的逻辑使用都在这里:src/backend/utils/fmgr/fmgr.c 以其中一个函数为例 DatumFloat4
./configure --help我们能看到两个编译开关: 所有涉及的逻辑使用都在这里:src/backend/utils/fmgr/fmgr.c 以其中一个函数为例 Datum Float4GetDatum(float4 X) { #ifdef USE_FLOAT4_BYVAL union { float4 value; int32 retval; } myunion; myunion.value = X; return SET_4_BYTES(myunion.retval); #else float4 *retval = (float4 *) palloc(sizeof(float4)); *retval = X; return PointerGetDatum(retval); #endif }看注释,是为了消除某些架构的函数在传递和返回 整形/浮点 时会使用不同方式,所以才使用这种奇怪的方式。 上边的程序很简单,因为 int 与 float 都是4字节,因此简单的将这4字节以int型返回。 其他部分处理类似。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |