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

d2ad2c76f1b98ad130add70cb49ac8a7.png

慕哥6287543

以下是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即使在具有慢速乘法指令的机器上,这也会比软件鸿沟更快。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值