7

我在使用 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

所以 times(98301,32767) 类似于 3.0*1.0。当时间的参数小于 32767 (1.0) 时,此代码可以完美运行,但带有上述参数的任何中间步骤都不应溢出 64 位 long。

有任何想法吗?

4

4 回答 4

9

long 不一定是 64 位。改用“long long”。

于 2010-02-22T16:20:40.407 回答
4

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

于 2010-02-22T16:22:01.167 回答
2

您可能有 32 位长。尝试long long改用。

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

于 2010-02-22T16:20:45.333 回答
2

C 标准只保证long至少有 32 位(在大多数 32 位平台上实际上是这种情况)。

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

于 2010-02-22T16:24:55.960 回答