./configure --help我们能看到两个编译开关:
--disable-float4-byval disable float4 passed by value
--disable-float8-byval disable float8 passed by value
所有涉及的逻辑使用都在这里: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型返回。
其他部分处理类似。