首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >80286:乘10最快的方法是什么?

80286:乘10最快的方法是什么?
EN

Stack Overflow用户
提问于 2020-04-04 18:46:51
回答 1查看 431关注 0票数 2

要把一个数字乘以任何2的倍数,我会把它移很多次。

有没有这样的技术可以在较短的周期内将一个数字乘以10?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-04 21:12:51

80286没有一个桶移位器,那是与80386一起推出的。根据微软宏汇编程序5.0文档(1987年)中的时序表,SHL reg,immed8采用5+n周期,而SHL reg,1使用2个周期。添加 reg,reg需要2个周期,MOV reg,reg。IMUL reg16,immed为21周期。因此,最快的乘以十的方法似乎是:

代码语言:javascript
复制
           ;       // cycles
shl ax, 1  ; *2    // 2
mov bx, ax ; *2    // 4
shl ax, 1  ; *4    // 6
shl ax, 1  ; *8    // 8
add ax, bx ; *10   // 10

或者,另一种选择是:

代码语言:javascript
复制
           ;      // cycles
mov bx, ax ; *1   // 2
shl ax, 1  ; *2   // 4
shl ax, 1  ; *4   // 6
add ax, bx ; *5   // 8
shl ax, 1  ; *10  // 10

不管是哪种方式都有十个周期。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61033121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档