首页 > 解决方案 > 无符号变量发生整数溢出

问题描述

我试图在 C 上做 100 的阶乘并且发生整数溢出,但我不明白为什么我的无符号变量变为负数。

int main(void)
{
    unsigned long value =1;
    for(unsigned long n = 0;n<100;n++){
        printf("This n %ld\n",value);
        value *= (n+1);
    }
    printf("%ld\n",value);
    return 0;
}

用无符号变量,变量容量溢出后,不应该再从0开始吗?

value 的第一个值:

This current value 2  
This current value 6  
This current value 24  
This current value 120  
This current value 720  
This current value 5040  
This current value 40320  
This current value 362880  
This current value 3628800  
This current value 39916800  
This current value 479001600  
This current value 6227020800  
This current value 87178291200  
This current value 1307674368000  
This current value 20922789888000  
This current value 355687428096000  
This current value 6402373705728000  
This current value 121645100408832000  
This current value 2432902008176640000  
This current value -4249290049419214848

这怎么可能?

标签: cunsignedinteger-overflow

解决方案


%ldinprintf将任何数字解释为已签名的数字。每个数字都可以读取为有符号或无符号。要打印你的 unsigned long as unsigned 你应该传递%luprintf.

无符号数和有符号数之间的区别在于编译器在处理此变量时将选择使用哪些汇编指令。在汇编级别,有一组指令旨在处理应该是有符号数的指令集和其他指令集来处理无符号数(例如,当您通过if语句检查变量的值时,如果它被声明为有符号,编译器将生成一些指令,如果不是,编译器将生成其他指令)。char c = -1unsigned char c = 255以完全相同的值存储在内存中。


推荐阅读