C语言用位移除以10,使用位移除以10?

本文揭示了Microsoft编译器如何通过预计算1/10*2^32并利用IMUL指令实现快速除法,提高ia32架构下整数除法性能,尤其适用于32位机器。这种技巧在有慢速乘法指令的环境下仍优于软件解决方案。
摘要由CSDN通过智能技术生成

以下是Microsoft编译器在使用小积分常量编译除法时所执行的操作。假设一台32位机器(代码可以相应调整):int32_t div10(int32_t dividend){

int64_t invDivisor = 0x1999999A;

return (int32_t) ((invDivisor * dividend) >> 32);}

这里发生的是我们乘以近似的1/10 * 2 ^ 32然后移除2 ^ 32。该方法可以适应不同的除数和不同的位宽。

这对ia32架构非常有用,因为它的IMUL指令会将64位产品放入edx:eax,而edx值将是所需的值。Viz(假设股息在eax中传递,商在eax中返回)div10 proc

mov    edx,1999999Ah    ; load 1/10 * 2^32

imul   eax              ; edx:eax = dividend / 10 * 2 ^32

mov    eax,edx          ; eax = dividend / 10

ret

endp

即使在具有慢速乘法指令的机器上,这也会比软件鸿沟更快。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值