C ++过早地溢出了

时间:2010-02-22 16:18:18

标签: c++ overflow integer-overflow

我遇到了一个奇怪的C ++问题,其中长数据类型在它应该存在之前很久就会溢出。我正在做的事情(到目前为止成功)是使整数表现得像浮点数,因此范围[-32767,32767]被映射到[-1.0,1.0]。它失败的地方是更大的参数表示浮动大于1.0:

inline long times(long a, long b) {
  printf("a=%ld b=%ld ",a,b);
  a *= b;
  printf("a*b=%ld ",a);
  a /= 32767l;
  printf("a*b/32767=%ld\n",a);
  return a;
}

int main(void) {
  printf("%ld\n",times(98301l,32767l));
}

我得到的输出是:

a=98301 b=32767 a*b=-1073938429 a*b/32767=-32775
-32775

所以时代(98301,32767)类似于3.0 * 1.0。当时间参数小于32767(1.0)时,此代码可以正常工作,但上述参数的中间步骤都不会溢出64位长。

有什么想法吗?

4 个答案:

答案 0 :(得分:9)

长不一定是64位。试试'long long'而不是。

答案 1 :(得分:4)

类型long不一定是64位。如果您使用的是32位体系结构(至少在MS Visual c ++上),则long类型为32位。请使用sizeof (long)查看。还有long long数据类型可能会有所帮助。

答案 2 :(得分:2)

你可能有32位长。请尝试使用long long

98301 * 32767 = 3221028867,而32位长溢出2147483648

答案 3 :(得分:2)

C标准仅保证long至少具有32位(大多数32位平台实际情况如此)。

如果您需要64位,请使用long long。它保证至少保持64位。