这是一个例子:
#include <stdio.h>int main(int argc,char** argv){ long long int a = -2205348223670655684LL; printf("%lld %lld %lld %lld %lld %lld\n",a % 20,a % 20L,a % 20LL,a % 20U,a % 20LU,a % 20LLU); return 0;}
和输出:
06001
有谁能解释为什么?我用GCC 4.8和5.1试过了
解决方法 C99第6.5.5 / 6节要求当a / b可表示时:(a/b) * b + a%b shall equal a
从6.5.5 / 3开始
The usual arithmetic conversions are performed on the operands.
有关算术转换的更多详细信息,请参阅第6.3.1.8节.
现在看来你的实现sizeof(long)= sizeof(long long)= 64位
对于前4种情况,有符号或无符号除数可以更改为分子类型(即long long int),但在最后2种情况下,除数必须更改(转换或重新解释为)为无符号类型,因为除数具有相同的宽度且是无符号的导致结果.
在某些系统中,sizeof(long)< sizoef(很长),第二个结果应该是不同的.
总结以上是内存溢出为你收集整理的C模运算与负除数和除数的差异是长期无符号的全部内容,希望文章能够帮你解决C模运算与负除数和除数的差异是长期无符号的所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)