Pet*_*ner 4 delphi recursion inline-method delphi-2009
" 使用内联函数有什么问题 "和" 递归函数可以内联 "是否适用于Delphi内联函数?此外,有谁知道如何在Delphi中处理递归内联函数?
Jim*_*eth 10
我的猜测可能不是因为内联只是一个建议,但让我们找出答案.
一个简单的递归阶乘例程:
function Factorial(const aNum: cardinal): cardinal;
begin
if aNum > 1 then
Result := Factorial(aNum - 1) * aNum
else
Result := 1;
end;
Run Code Online (Sandbox Code Playgroud)
这是对它的调用的反汇编:
// fact := Factorial(5);
mov eax,$00000005
call Factorial
mov ebx,eax
Run Code Online (Sandbox Code Playgroud)
并且例程本身的反汇编:
// 9: begin
push ebx
mov ebx,eax
// 10: if aNum > 1 then
cmp ebx,$01
jbe $0040ab30
// 11: Result := Factorial(aNum - 1) * aNum
mov eax,ebx
dec eax
call Factorial
imul ebx
pop ebx
ret
// 13: Result := 1;
0040ab30: mov eax,$00000001
// 14: end;
pop ebx
ret
Run Code Online (Sandbox Code Playgroud)
现在我们将其内联并查看调用中的不同之处:
// 21: fact := Factorial(5);
mov eax,$00000005
call Factorial
mov ebx,eax
Run Code Online (Sandbox Code Playgroud)
例程本身:
// 9: begin
push ebx
mov ebx,eax
// 10: if aNum > 1 then
cmp ebx,$01
jbe $0040ab30
// 11: Result := Factorial(aNum - 1) * aNum
mov eax,ebx
dec eax
call Factorial
imul ebx
pop ebx
ret
// 13: Result := 1;
0040ab30: mov eax,$00000001
// 14: end;
pop ebx
ret
Run Code Online (Sandbox Code Playgroud)
它们对我来说都是一样的,所以我会坚持我原来的假设并说它们不受支持.
顺便说一下:这是在Delphi 2009中.
| 归档时间: |
|
| 查看次数: |
1108 次 |
| 最近记录: |