План лекций по курсу ОП 2008/09 — весенний семестр

Материал из Вики ИТ мехмата ЮФУ
Перейти к: навигация, поиск

Лекция 1 ( 17.02.09 )

Конспект

<xh4> Файлы </xh4> Определение. Преимущества файлов.

Классификация файлов

по типу компонент (текстовые, двоичные (типизированные,бестиповые))
по способу доступа (последовательный, произвольный)

Понятие файловой переменной, файлового указателя.

Буферизация в файлах.

Подпрограммы для работы с закрытыми файлами

procedure Rename(f, name);
procedure Erase(f);
function FileExists(name): boolean;
function DeleteFile(name): boolean;
function RemoveDir(name): boolean;
function GetCurrentDir: string;
function SetCurrentDir(name): boolean;
function CreateDir(name): boolean;
function ExtractFileName(name): string;
function ExtractFileExt(name): string;
function ExtractFilePath(name): string;

Ошибки ввода-вывода при работе с файлами

  1. файл открыли, но забыли выполнить Assign
  2. открыли, но файла нет на диске (или нет прав доступа на чтение)
  3. попытка считывания за концом файла

Пример. Ошибка считывания за концом файла.

Оператор try..finally.

Лекция 2 ( 18.02.09 )

Конспект

Подпрограммы для работы с типизированными файлами

Truncate
FileSize
FilePos
Seek

Варианты использования:

Seek(FileSize(f)) - переместить файловый указатель за конец файла (Eof(f)=True)
Seek(FilePos(f)-1) - вернуться на 1 позицию назад

Пример 1. Добавление 0 в конец файла

Пример 2. Возведение всех элементов файла в квадрат.

Пример 3. Использование в базах данных - перевод Иванова в 10 группу в виде наказания

Пример 4. Сортировка файла

for var i:=FileSize(f)-1 downto 1 do
for var j:=0 to i-1 do
begin
  Seek(f,j);
  read(f,x,y);
  if x>y then
  begin
    Seek(f,j);
    write(f,y,x);
  end;
end;

Подпрограммы для работы с текстовыми файлами

Append
Eoln
SeekEof
SeekEoln
Read, Write - особенности
Readln, Writeln

Пример. Обработка строк в текстовых файлах.

Лекция 3 ( 24.02.09 )

Конспект

<xh4> Указатели </xh4>

Адрес. Переменная-указатель.

Для чего нужны указатели?

Типизированные и бестиповые указатели.

Нулевой указатель.

Операция разыменования.

Указатели и явное приведение типа. Пример: типы pointer, pinteger и preal.
Доступ к памяти, имеющей другое внутреннее представление.

Динамическая память. Явное выделение динамической памяти.
Процедуры New и Dispose.

Ошибки при работе с динамической памятью

  • Использование неинициализированного указателя
  • Висячие указатели
  • Утечка памяти

Неявные указатели в Pascal

<xh4> Классы-начало </xh4> Переменная типа класс как ссылка. Сравнение с записями.

Вызов конструктора и выделение динамической памяти.

Лекция 4 ( .09 )

[[ | Конспект]]

Шаблоны классов.

Решение проблемы освобождения памяти, занимаемой объектами классов: сборка мусора (.NET, Java).

Управляемая динамическая память и ее возврат. Отсутствие утечки памяти.

Динамические структуры данных. Списки

Виды списков. Рисунки.

Односвязные линейные списки

Класс узла списка (шаблонный)

Стандартные операции с односвязными линейными списками

  • Вставка элемента в начало
  • Удаление элемента из начала
  • Вставка после текущего
  • Удаление после текущего
  • Проход по списку

Двусвязные линейные списки

Стандартные операции с двусвязными линейными списками

  • Инициализация
  • Добавление в начало, конец
  • Удаление из начала, конца
  • Вставка элемента перед текущим, после текущего
  • Удаление текущего
  • Объединение двух списков

Помещение операций по работе со списком внутрь класса

Лекция 5 ( .09 )

[[ | Конспект]]

Лекция 6 ( .09 )

[[ | Конспект]]

Рекурсия

Определение рекурсии.

Рекурсивные определения. Праворекурсивное и леворекурсивное определения.

Простые примеры использования рекурсии.

Понятие рекурсивного спуска и рекурсивного возврата. Графическое изображение рекурсивного спуска и рекурсивного возврата

Примеры вычисления n!, a^n.

Рекурсия и списки. Операции car и cdr

Лекция 7 ( .09 )

[[ | Конспект]]

Лекция 8 ( .09 )

[[ | Конспект]]

Лекция 9 ( .09 )

[[ | Конспект]]

Лекция 10 ( .09 )

[[ | Конспект]]

Лекция 11 ( .09 )

[[ | Конспект]]

Лекция 12 ( .09 )

[[ | Конспект]]

Лекция 13 ( .09 )

[[ | Конспект]]

Лекция 14 ( .09 )

[[ | Конспект]]

Лекция 15 ( .09 )

[[ | Конспект]]

Лекция 16 ( .09 )

[[ | Конспект]]

Лекция 17 ( .09 )

[[ | Конспект]]