学习笔记 整数运算 乘以常数

在很多机器上,执行常数乘法会非常慢,需要更多的时钟周期,但是执行其他运算(加、减、与、或、非、异或、移位)只需要一个时钟周期,因此编译器会使用加、减、移位

的组合来替代乘法运算。

乘以2的幂:

例如  11 *4=44;   则11=01011;44=101100; 4=2^2;

                                  可以看出11*4等价于将11左移2位;

推广下:

         比如11*5;可以转换位 11*(2^2)+11*(2^0)=(11<<2)+11;

         比如11*14;可以转换位11*(2^3+2^2+2^0)也能转换位11*(2^4-2^1);对于前一种将进行3次移位运算,而后面一种只进行2次;所以编译器可以选择第二种方案以优化运算速度。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值