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; } 和输出:
有谁能解释为什么?我用GCC 4.8和5.1试过了 解决方法
C99第6.5.5 / 6节要求当a / b可表示时:
从6.5.5 / 3开始
有关算术转换的更多详细信息,请参阅第6.3.1.8节. 现在看来你的实现sizeof(long)= sizeof(long long)= 64位 对于前4种情况,有符号或无符号除数可以更改为分子类型(即long long int),但在最后2种情况下,除数必须更改(转换或重新解释为)为无符号类型,因为除数具有相同的宽度且是无符号的导致结果. 在某些系统中,sizeof(long)< sizoef(很长),第二个结果应该是不同的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- c# – 如何在单元测试中将Thread.CurrentPrincipal重置为un
- Flex 下兼容谷歌,百度地图服务
- 高性能I/O设计模式Reactor和Proactor
- ruby-on-rails – Rails多态的has_many:through
- ruby-on-rails – 是否可以使用Ruby 1.9x运行Ruby on Rails
- libc is_copy_constructible对我来说似乎是错误的
- Consuming XML Web Services in iPhone Applications
- ReactiveCocoa之RAC映射(七)
- 如何在Swift中导入没有Xcode项目的模块
- SQlite3高级应用篇(C/C++编程接口)