./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型返回。
其他部分处理类似。