С Новым годом! Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Автор канал по Лиспу
 Аватар для Regrin1
25 / 23 / 2
Регистрация: 10.08.2021
Сообщений: 357

Как работает вызов функции?

11.10.2022, 02:42. Показов 421. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Скажите пожалуйста, как работает вызов функции? Я слышал, что там есть какой-то стек, но четкой картины у меня в голове нет. Не могли бы вы мне всё разъяснить? Подкинете ссылки на статьи?
Заранее спасибо!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.10.2022, 02:42
Ответы с готовыми решениями:

Как в JQuery работает вызов функции?
Здравствуйте, я не понимаю а как в JQuery работает вызов функции? Если я хочу написать функцию то пишу так: function...

Не понимаю, как работает вызов функции. От пролога до эпилога
Приветствую, форумчане. Ступил на путь изучения computer science с книги небезизвестного автора Эндрю Таненбаума "Архитектура...

Не работает без указателя вызов функции в функции
int AmountOfSquares(int **Array) { NumberOfSquares++; for (i = iTempTwo + 1; ((i<(iTemp + SizeOfSquare)) &&...

4
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38167 / 21102 / 4307
Регистрация: 12.02.2012
Сообщений: 34,690
Записей в блоге: 14
11.10.2022, 04:46
Опс... Вот это вопрос! Да, практически во всех языках для вызова функций используется стек. Прилагаю маленькую презентацию, которая несколько проясняет вопрос (на примере C/С++)
Вложения
Тип файла: zip Механизм_вызова_функций.zip (76.8 Кб, 10 просмотров)
3
4528 / 3522 / 358
Регистрация: 12.03.2013
Сообщений: 6,038
11.10.2022, 11:44
Стандарт ничего такого не описывает, конечно. Но даже не говоря о конкретных реализациях, вызовы функций по своей природе образуют стек: last in first out. Если код функции вызывает другую функцию, нужно переключиться на эту вторую, вычислить её значение, и вернуться к коду первой функции.

Можно представить себе, что при вызове функции выделяются какие-то ресурсы (например, память для локальных переменных), а также запоминается место возврата - в какую точку программы нужно вернуться после выполнения функции. (Programmers don't die, they GOSUB without RETURN. ). После завершения ресурсы освобождаются и программа переходит в указанную точку. Если вызовов очень много, ресурсов приходится тоже выделять много, и получается stack overflow.

Хвостовая рекурсия - это хак, когда вызов не просто добавляется в верхушку стека, а заменяет её.

В сикпе написано весьма подробно.
2
331 / 199 / 9
Регистрация: 12.05.2015
Сообщений: 334
11.10.2022, 13:29
Цитата Сообщение от Regrin1 Посмотреть сообщение
Здравствуйте!
Скажите пожалуйста, как работает вызов функции? Я слышал, что там есть какой-то стек, но четкой картины у меня в голове нет.
Это неправильнй вопрос. Компилятор оптимизирующий и нас должно волновать как он оформит вызов в конкретном коде. А делать он это может по разному. Иначем тот компилятор был бы програмисту без надобности.
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
(describe #'cl:1+)
 
#<FUNCTION 1+>
;  [compiled function]
 
 
;Lambda-list: (NUMBER)
;Declared type: (FUNCTION (NUMBER) (VALUES NUMBER &OPTIONAL))
;Derived type: (FUNCTION (T) (VALUES NUMBER &OPTIONAL))
;Documentation:
;  Return NUMBER + 1.
;Known attributes: foldable, flushable, unsafely-flushable, movable
;Source file: SYS:SRC;CODE;NUMBERS.LISP
(disassemble #'cl:1+)
 
; disassembly for 1+
; Size: 26 bytes. Origin: #x94B5965
; 65:       895DFC           MOV [EBP-4], EBX                 ; no-arg-parsing entry point
; 68:       BF04000000       MOV EDI, 4
; 6D:       8BD3             MOV EDX, EBX
; 6F:       E8CCA7B4F7       CALL #x1000140                   ; GENERIC-+
; 74:       8B5DFC           MOV EBX, [EBP-4]
; 77:       8BE5             MOV ESP, EBP
; 79:       F8               CLC
; 7A:       5D               POP EBP
; 7B:       C3               RET
; 7C:       CC12             BREAK 18                         ; INVALID-ARG-COUNT-ERROR
; 7E:       09               BYTE #X09                        ; ECX
NIL
Смотреть на правую колонку
1
 Аватар для chessman2
161 / 141 / 10
Регистрация: 21.10.2012
Сообщений: 479
11.10.2022, 19:37
В простейшем случае в так.
К примеру есть код:
...
Assembler
1
2
call func1
call func2
Команда call помещает в стек (отдельная область памяти)
адрес по которому находится код вызова функции func2

Команда ret извлекает из стека адрес вызова функции func2
и передает управление по этому адресу.

Assembler
1
2
3
4
5
6
7
; код функции func1
func1:
 
    ; некие команды, 
    ; в том числе вызовы других функций
 
    ret ; в этой точке будет вызвана func2
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.10.2022, 19:37
Помогаю со студенческими работами здесь

Не работает вызов функции
printf(&quot;&lt;input type='button' onclick='podgr(%s, %s);' value='Подгрузить еще..'/&gt;&quot;,$rows, $coll); Не вызывает функцию при нажатии на...

Не работает вызов функции
Всем привет! написал 2 функции... при запуске программы - первая функция работает норм: ввожу данные, а при вызове 2-ой функции ничего не...

Не работает вызов функции
Не работает вызов функции, плюс к тому же не работают проверочные тролли (не выводят 10). Помогите найти ошибку. ...

Не работает вызов функции
Добрый день! Я изучаю с++ и у меня возникла проблема при разработке учебного калькулятора. Я хочу добавить в него возможность возвращения к...

Вызов функции не работает
Из трея вызываю функцию: 1 кнопка IBlock.Enabled(1); // блокировка 2 кнопка IBlock.Enabled(0); // 0 разблокировка ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru