加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 10:00:07 所属栏目:百科 来源:网络整理
导读:嗨我知道在C中,负股息的模数会导致负模数,但我发现使用长无符号除数或长无符号除数的负股息模数会产生正模数! 这是一个例子: #include stdio.hint main(int argc,char** argv){ long long int a = -2205348223670655684LL; printf("%lld %lld %lld %lld %l
嗨我知道在C中,负股息的模数会导致负模数,但我发现使用长无符号除数或长无符号除数的负股息模数会产生正模数!

这是一个例子:

#include <stdio.h>

int main(int argc,char** argv)
{
    long long int a = -2205348223670655684LL;
    printf("%lld %lld %lld %lld %lld %lldn",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(很长),第二个结果应该是不同的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读