C模运算与负除数和除数的差异是长期无符号的

C模运算与负除数和除数的差异是长期无符号的,第1张

概述嗨我知道在C中,负股息的模数会导致负模数,但我发现使用长无符号除数或长无符号除数的负股息模数会产生正模数! 这是一个例子: #include <stdio.h>int main(int argc, char** argv){ long long int a = -2205348223670655684LL; printf("%lld %lld %lld %lld %lld % 嗨我知道在C中,负股息的模数会导致负模数,但我发现使用长无符号除数或长无符号除数的负股息模数会产生正模数!

这是一个例子:

#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模运算与负除数和除数的差异是长期无符号的所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1216957.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存