Я сталкиваюсь со странным поведением встроенной сборки Delphi, как показано в этой очень короткой и простой программе:
program test;
{$APPTYPE CONSOLE}
uses
SysUtils;
type
TAsdf = class
public
int: Integer;
end;
TBlah = class
public
asdf: TAsdf;
constructor Create(a: TAsdf);
procedure Test;
end;
constructor TBlah.Create(a: TAsdf);
begin
asdf := a;
end;
procedure TBlah.Test;
begin
asm
mov eax, [asdf]
end;
end;
var
asdf: TAsdf;
blah: TBlah;
begin
asdf := TAsdf.Create;
blah := TBlah.Create(asdf);
blah.Test;
readln;
end.
Это просто ради примера (mov
вставка [asdf]
в eax
мало что делает, но работает для примера). Если вы посмотрите на сборку для этой программы, вы увидите, что
mov eax, [asdf]
было превращено в
mov eax, ds:[4]
(как представлено OllyDbg), что, очевидно, дает сбой. Однако, если вы сделаете это:
var
temp: TAsdf;
begin
temp := asdf;
asm
int 3;
mov eax, [temp];
end;
меняется на
mov eax, [ebp-4]
который работает. Почему это? Я обычно работаю с C ++, и я привык к использованию таких экземпляров, возможно, я неправильно использую переменные экземпляра.
РЕДАКТИРОВАТЬ: Да, это было. Изменение mov eax, [asdf]
на mov eax, [Self.asdf]
устраняет проблему. Извините за это.