При написании программ, часто возникает такая ситуация, когда необходимо одну и ту же последовательность команд использовать в разных частях программы. Было бы неразумным дублировать ее в каждом таком месте. Вместо этого последовательность оформляют отдельным блоком и помещают в самый конец программы, а в те места, где она используется, ставят "ссылки" на этот блок. Такой блок называют функцией, а "ссылки" на него - вызовами функции. Все, кажется, понятно, кроме одного: в разных частях программы функция должна работать с разными данными, следовательно, в функцию их надо как-то передать. Такие данные называются аргументами этой функции. Рассмотрим описание вызова функции на примере MessageBoxA():
MessageBoxA (hWnd, lpText, lpCaption, uType);
Аргументы в функцию передаются через стек. В программе это выглядит следующим образом:
некоторый код ... push 20h <-передача аргумента uType push 00440010 <-передача аргумента lpCaption push 0044003E <-передача аргумента lpText push ebx <-передача аргумента hWnd call USER32!MessageBoxA <-вызов функции MessageBoxA() ... продолжение программы
Мы с Вами в основном будем иметь дело с функциями Win32 API. Win32 API (Aplication Programming Interface) - набор функций (и не только, но сейчас нас интересуют именно функции), которые Windows предоставляет разработчику для использования в своих программах при создании интерфейса (в данном случае это слово означает взаимодействие) с ОС (Операционная Система). Все Win32 API функции располагаются в .dll файлах (специальные библиотеки функций, динамически подключаемые к программе при ее выполнении, разговор о них еще впереди).
Для API-функций приняты следующие соглашения:
Кроме передачи данных в функцию, она сама тоже должна что-то возвращать в программу. Возвращаемое функцией значение (обычно одно, но бывает и больше, о таких случаях мы поговорим, когда они встретятся нам в какой-нибудь программе) передаются в регистре eax.
Вот, в общем-то, и все, что Вы пока должны знать о функциях. Дополнительная информация будет даваться в следующих статьях, по мере необходимости.
Материалы находятся на сайте http://cracklab.narod.ru/doc/