发布于 2014-05-09 15:37:36
22楼
dint最大的数字是2147483647
那么在accu1中的存储是0111_1111_1111_1111_1111_1111_1111_1111。什么意思了,就是说在accu1中存储这么一串二进制数码的时候,才能被解释为2147483647(dint格式)。而且这个是唯一的。除此以外没有任何一串二进制数码可以被解释为2147483647(dint格式)。
但是,根据单精度浮点数规则,根本就找不到一个浮点数和这个32位二进制数相对应。
也就是说找不到一个浮点数变换成2147483647(dint格式),因为,根本就没有一个浮点数和上面的二进制数码相对应。
事实上,当accu1中出现这么一串二进制数码的时候,如果解释为浮点数,将出现:+1.#qe+000。这个是单精度浮点数的规约。