微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在C中签名与无符号操作

很简单的问题:

我有一个程序在内部和长时间内进行大量的数学计算.为了适应一点点,我做了很长的长期没有签名,因为我只处理正数,现在可以得到更多的价值观.

奇怪的是,这给了我一个15%的性能提升,我确认是简单地做了所有长的未签名的.

这可能吗?无符号数字的数学运算是否真的更快?我记得阅读没有任何区别,编译器会自动选择最快的方式去签名或者无符号.这个15%的提升是否真的使得vars没有签名,或者可能会在我的代码中受到影响?

而且,如果真的是使vars无符号,那么我应该把所有的东西(甚至int)都没有签名,因为我不需要负数,如果我可以保存它,每一秒都是重要的.

解决方法

在某些操作中,有符号整数更快,在其他操作中,无符号更快:

>在C中,可以假定有符号整数运算不包括.例如,编译器将在循环优化中利用这一点.比较可以类似地优化. (这也可能导致细微的错误,如果你不期望这个).
>另一方面,无符号整数没有这个假设.然而,不必处理标志是一些操作的一大优点,例如:除法.由两个恒定幂组成的无符号除法是一个简单的移位,但是(根据你的舍入规则),负数的条件是一个有条件的.

就个人而言,我习惯只使用无符号整数,除非我真的有一个需要签名的值.对于表现而言,这不是正确的.

您可能会看到效果放大了很长时间,(我猜)是64位在你的情况. cpu通常没有处理这些类型的单个指令(在32位模式下),因此签名操作的轻微增加的复杂性将更加明显.

原文地址:https://www.jb51.cc/c/111735.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐