C++过早地溢出了

rho*_*dri 7 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));
}
Run Code Online (Sandbox Code Playgroud)

我得到的输出是:

a=98301 b=32767 a*b=-1073938429 a*b/32767=-32775
-32775
Run Code Online (Sandbox Code Playgroud)

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

有任何想法吗?

Gre*_*ndt 9

long不一定是64位.试试'long long'而不是.