Код: Выделить всё
void func()
{
printf("hello");
}
int main()
{
printf("%p",func);
func();
return 0;
}
Диассемблирование строки func() дает мне вызов _func (0F811AEh) — пока все хорошо.
Но дизассемблирование содержимого func >, первая инструкция появляется по адресу 00F813C0.
Итак, я «пошел посмотреть», что находится по адресу 00F811AE, и там я нашел jmp func (0F813C0h).
Подводя итог, можно сказать, что вызов функции компилируется как две инструкции:
Код: Выделить всё
call _func (0F811AEh)
jmp func (0F813C0h)
Похоже, что одна jmp выполнит эту работу. Я спрашиваю даже об этом, потому что у меня такое ощущение, что другие компиляторы делают это аналогичным образом (конечно, в зависимости от базовой архитектуры аппаратного обеспечения).
Подробнее здесь: https://stackoverflow.com/questions/253 ... ead-of-one