
- •Ответы на вопросы по курсу “системное программирование”, 1997 г.
- •Состав и функции основных блоков вс: процессора, оперативной памяти, устройства управления, внешних устройств.
- •Структурная схема машины фон Неймана:
- •Адресация на примере процессора 8086.
- •Двоичное кодирование информации. Представление элементарных типов данных: натуральные числа, целые числа со знаком, числа с плавающей точкой.
- •Представление графической информации – растровое и векторное представления, разрешающая способность, полутоновые и цветные изображения, палитры.
- •Представление звуковой информации – общее понятие о дискретизации и квантовании звуковых сигналов, точность представления звуковых колебаний.
- •Форматы хранения оцифрованного звука в файлах:
- •Общая структура машинных команд, адресность. Способы адресации операндов. Расслоение памяти, выравнивание, кэш-память.
- •Общая структура машинных команд.
- •Классификация объектных данных в программах на языках высокого уровня. Агрегатные
- •Базовые типы
- •Указатели и динамические структуры данных: стеки, списки, очереди, деревья.
- •24. Способы выделения памяти в программах: абсолютное, статическое, динамическое и автоматическое распределения. Механизм стека и кучи при реализации процессоров языка программирования.
- •29. Общая структура программного модуля для микропроцессора 80х86 – регистр bp, локальные переменные, глобальные переменные, параметры.
- •30. Сегментация памяти. Типы программных сегментов, их использование в программах.
- •Использование многомодульной структуры необходимо:
- •34. Технология разработки программ – трансляция и редактирование связей. Понятие об исходном, объектном, выполняемом модулях.
- •37. Разрешение внешних ссылок, функция автовызова, библиотеки объектных модулей и их использование.
- •38. Типы внешних ссылок и общих имен. Статическое и динамическое разрешение ссылок.
- •39. Динамическое распределение памяти, оверлейные программы. Общая структура объектного модуля.
- •45. Системная архитектура 80386: сегментирование, страничная организация, средства авторизации и защиты.
24. Способы выделения памяти в программах: абсолютное, статическое, динамическое и автоматическое распределения. Механизм стека и кучи при реализации процессоров языка программирования.
Статическое выделение памяти – выделение памяти под данные внутри сегмента данных программы. Такие данные существуют на протяжении всей жизни программы до ее завершения.
Автоматическое распределение – выделение памяти под данные в стеке. Такие данные существуют на протяжении работы текущей подпрограммы (функции или процедуры), затем уничтожаются.
Динамическое выделение – выделение памяти под данные самой программой, когда это необходимо. Время жизни таких данных зависит от программы.
В стеке размещаются данные для возврата из подпрограмм, а также их аргументы и автоматические данные. Все это может потребовать достаточно большого размера стека. Как правило, программист может определять размер стека в программе.
Куча. Для реализации динамических структур данных используют т.н. кучу (heap). Это объем памяти, в котором можно выделить участок для произвольного элемента данных. Для кучи есть 2 операции: выделения памяти ALLOCATE и освобождения FREE. Эти функции не делают никаких действий с собственно памятью. При выделении программист получает адрес, а при освобождении доступный объем кучи становится больше. Одного адреса для этих операций недостаточно, требуется еще и размер элемента данных. Если указатель типизированный, размер будет получен автматически. В случае нетипизированного указателя размер должен быть передан в функцию.
Для реализации кучи ЯВУ снабжаются диспетчерами памяти, которые выделяют и освобождают память, имеют сведения о ее фрагментации, знают наибольший кусок свободной памяти и ее общее количество и т.п. При ненадобности память должна своевременно освобождаться. При использовании динамической памяти возможноа ситуация образования «мусора» – кусков памяти, на которые утеряны ссылки, но которые не были своевремменно освобождены, поэтому менеджер считает их занятыми. Для оптимизации известна процедура “уборка мусора” – перестройка динамических структур с освобождением памяти из-под тех данных, на которые отсутствуют ссылки.
25. Среды ссылок: глобальная, локальная и нелокальная их реализация в исполняющих системах ЯВУ.
26. Понятие программного модуля: подпрограммы, функции, сопрограммы.
Модульное программирование подразумевает разбиение программы на подпрограммы по специфике обрабатываемых данных. Для этой цели в ЯВУ используются функции и процедуры. При вызове подпрограммы в стеке сохраняется текущее значение счетчика команд (ближняя модель вызова) и значение сегмента кода (дальняя модель вызова). При использовании дальней модели вызова подпрограмма необязательно должна находиться в том же сегменте, что и вызывающая программа. По окончании выполнения кода подпрограммы эти данные восстанавливаются, управление передается на следующий оператор после оператора вызова процедуры.
До вызова подпрограммы в стек помещаются параметры – аргументы подпрограммы. Если передан не сам аргумент, а его адрес, то подпрограмма может изменить аргумент, в противном случае нет, т.к. по завершению работы подпрограммы стек очищается от аргументов. Отличие функций от процедур в том, что функции могут возвращать значения в вызывающую программу и их можно присваивать, например, какой-либо переменной. В действительности функция при возврате значений просто модифицирует регистры процессора, а ЯВУ по соглашению использует данные из этих регистров.
27. Способы передачи управления между модулями. Применение стека для организации связи в подпрограммах и функциях.
Переписать 26 без первых 2 предложений.
28. Параметры подпрограмм и функций. Способы передачи параметров – по значению, по ссылке, по имени.
До вызова подпрограммы в стек помещаются фактические параметры – аргументы подпрограммы. Если требуется изменит аргумент в процедуре, то передается не сам аргумент, а его адрес. Существует два способа передачи параметров в подпрограмму для 8086 – соглашения о передаче параметров в С и Паскале. При передаче параметров первым способом запись аргументов в стек идет с последнего до первого, в Паскале наоборот.
Передача самого аргумента – передача параметра по значению. Передача адреса аргумента – передача по ссылке.
В С можно писать подпрограммы с переменным числом параметров, однако это не рекомендуется, т.к. стек имеет ограниченный размер и не желательно передавать по значению элементы данных большого размера.
После выполнения пролога все параметры подпрограммы имеют отрицательное смещение от регистра BP. После выполнения пролога, как правило, в стеке выделяется место под локальные переменные.
По окончании работы процедуры стек очищается от локальных переменнных и параметров.