smali代码问题

时间:2016-01-11 14:06:22

标签: android disassembly smali

让我们假设以下示例代码

public static int addition() {
int result = 1;
for(int i = 1; i < 10000 ; i++)
result = result + i;
}

和相应的smali代码(0002在if-ge旁边):

const/4 v0,#int 1
move v1,v0
const/16 v2,#int 10000
if-ge v0,v2,<0x0a>
add-int/2addr v1,v0
add-int/lit8 v0,v0,#int 1
goto <0002>
return v1

我试图理解相应的smali(汇编)代码,但遇到了一条对我来说毫无意义的行(标有???)。如果我没有弄错,v1的值每轮增加v0的值,这根本没有意义 - 第一轮:v1 = 2;第二轮v1 = 4等等

put 1 into register v0          // v0 = 1 
move value register v0 into v1  // v0 = 1 ; v1 = 1
put 10000 into register v2      // v0 = 1 ; v1 = 1 ; v2 = 10000 
if v0 >= v2 goto 0x0a           // v0 = 1 ; v1 = 1 ; v2 = 10000 
v1 = v1 + v0           (???)    // v0 = 1 ; v1 = 2 ; v2 = 10000
v0 = 1 + v0                     // v0 = 2 ; v1 = 2 ; v2 = 10000
goto 0x02
return v1

我想我误解了其中一条线。我究竟做错了什么?

1 个答案:

答案 0 :(得分:0)

是的,这与您发布的java代码相匹配。 v1resultv0i

重新编写您对代码的分析:

put 1 into variable i           // i = 1 
move value i into result        // i = 1 ; result = 1
put 10000 into register v2      // i = 1 ; result = 1 ; v2 = 10000 
if i >= v2 goto 0x0a            // i = 1 ; result = 1 ; v2 = 10000 
result = i + result             // i = 1 ; result = 2 ; v2 = 10000
i = 1 + i                       // i = 2 ; result = 2 ; v2 = 10000
goto 0x02
return result

您的问题是关于add-int/2addr v1,v0指令,具体类似于原始java中的result = result + i;行。