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

这篇博客介绍了Microsoft编译器如何使用小积分常量进行除法运算,特别是在32位机器上的优化。通过乘以1/10的近似值(0x1999999A)并右移32位,可以快速得到整数除以10的结果。这种方法适用于不同除数和位宽,并且在IA32架构中特别有效,因为它利用了IMUL指令将乘法结果的高32位(即所需的商)直接放入edx寄存器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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、付费专栏及课程。

余额充值