【发布时间】:2013-01-04 16:53:05
【问题描述】:
这是我试图转换为 gcc 风格的 asm 内联汇编代码的实际代码。
#include<iostream>
using namespace std;
int reverse(int num);
int main(){
int num;
cout << "enter number: ";
cin >> num;
cout << endl;
cout << reverse(num);
return 0;
}
int reverse(int num){
if(num == 0 || num == 1){
return num;
}
__asm
{
xor eax, eax
xor ecx, ecx
mov ebx, num
clc ; clear carry
not_found:
inc ecx
shl ebx, 1
jnc not_found
rcr eax, 1
mov edx, ecx
again:
shl ebx, 1
rcr eax, 1
inc ecx
cmp ecx, 32
jne again
dec edx
again2:
shr eax, 1
dec edx
cmp edx, 0
jne again2
}
}
由于我无法使用 gcc 编译上述代码,我尝试将其转换为可以由 gcc 编译器成功编译的东西,但到目前为止我无法产生任何有意义的结果。
【问题讨论】:
-
你能提供更多关于这个 sn-p 的上下文(temp,num 的声明)。它对我来说编译得很好。
-
不是汇编向导,但我在
shll中看到两个l,这可能意味着这是long int版本,num的类型是什么确切 ? -
也提供您的架构可能会有所帮助。
-
是的,它对我来说也可以编译 32 位和 64 位。当然这是对内联汇编的可怕滥用,我当然希望最终它会成为更有意义的代码。另请注意
clc没有效果,因为shl不读取进位。 -
@Jester, Bo:你太不仁慈了。我假设这是一个代码 sn-p。
标签: c++ gcc assembly x86 inline-assembly