Книга по программированию в Unix с использованием FPC
(Free Pascal Compiler).
Приведены основные понятия и приемы программирования в Unix, примеры программ,
задания для самостоятельного выполнения.
Формат MS Word. 418с.
18.09.2005 681k
А.П. Полищук, С.А. Семериков
СИСТЕМНОЕ ПРОГРАММИРОВАНИЕ В UNIX
средствами Free Pascal
От автора:
Целевая аудитория книги состоит из программистов,
уже знакомых с UNIX, которые собираются разрабатывать программное
обеспечение для ОС UNIX на языке Pascal.
Эта книга в равной мере подойдет разработчикам системного программного
обеспечения и прикладных или деловых приложений - фактически всем,
кто серьезно интересуется разработкой программ для ОС UNIX.
Замечания и предложения по содержанию и оформлению книги присылайте на e-mail.
Содержание
Предисловие
О книге
Назначение этой книги
Спецификация Х/Open
Структура книги
Что вы должны знать
Соглашения
Глава 1. Основные понятия и терминология
1.1. Файл
1.1.1. Каталоги и пути
1.1.2. Владелец файла и права доступа
1.1.3. Обобщение концепции файла
1.2. Процесс
1.2.1. Межпроцессное взаимодействие
1.3. Системные вызовы и библиотечные подпрограммы
Глава 2. Файл
2.1. Примитивы доступа к файлам в системе UNIX
2.1.1. Введение
2.1.2. Системный вызов fdopen
2.1.3. Создание файла при помощи вызова fdopen
2.1.4. Системный вызов fdcreat
2.1.5. Системный вызов fdclose
2.1.6. Системный вызов fdread
2.1.7. Системный вызов fdwrite
2.1.8. Пример copyfile
2.1.9. Эффективность вызовов fdread и fdwrite
2.1.10. Вызов fdseek и произвольный доступ
2.1.11. Пример: гостиница
2.1.12. Дописывание данных в конец файла
2.1.13. Удаление файла
2.1.14. Системный вызов fcntl
2.2. Стандартный ввод, стандартный вывод и стандартный вывод диагностики
2.2.1. Основные понятия
2.2.2. Программа io
2.2.3. Использование стандартного вывода диагностики
2.3. Стандартная библиотека ввода/вывода: взгляд в будущее
2.4. Системные вызовы и переменная linuxerror
2.4.7. Подпрограмма perror
Глава 3. Работа с файлами
3.1. Файлы в многопользовательской среде
3.1.1. Пользователи и права доступа
3.1.2. Права доступа и режимы файлов
3.1.3. Дополнительные права доступа для исполняемых файлов
3.1.4. Маска создания файла и системный вызов umask
3.1.5. Вызов fdopen и права доступа к файлу
3.1.6. Определение доступности файла при помощи вызова access
3.1.7. Изменение прав доступа при помощи вызова chmod
3.1.8. Изменение владельца при помощи вызова chown
3.2. Файлы с несколькими именами
3.2.1. Системный вызов link
3.2.2. Системный вызов unlink
3.2.3. Системный вызов frename
3.2.4. Символьные ссылки
3.2.5. Еще об именах файлов
3.3. Получение информации о файле: вызов fstat
3.3.1. Подробнее о вызове chmod
Глава 4. Каталоги, файловые системы и специальные файлы
4.1. Введение
4.2. Каталоги с точки зрения пользователя
4.3. Реализация каталогов
4.3.1. Снова о системных вызовах link и unlink
4.3.2. Точка и двойная точка
4.3.3. Права доступа к каталогам
4.4. Использование каталогов при программировании
4.4.1. Создание и удаление каталогов
4.4.2. Открытие и закрытие каталогов
4.4.3. Чтение каталогов: вызовы readdir и rewinddir
4.4.4. Текущий рабочий каталог
4.4.5. Смена рабочего каталога при помощи вызова chdir
4.4.6. Определение имени текущего рабочего каталога
4.4.7. Обход дерева каталогов
4.5. Файловые системы UNIX
4.5.1. Кэширование: вызовы sync и fsync
4.6. Имена устройств UNIX
4.6.1. Файлы блочных и символьных устройств
4.6.2. Структура tstat
4.6.3. Информация о файловой системе
4.6.4. Ограничения файловой системы: процедуры pathconf и fpathconf
Глава 5. Процесс
5.1. Понятие процесса
5.2. Создание процессов
5.2.1. Системный вызов fork
5.3. Запуск новых программ при помощи вызова ехес
5.3.1. Семейство вызовов ехес
5.3.2. Доступ к аргументам, передаваемым при вызове exec
5.4. Совместное использование вызовов ехес и fork
5.5. Наследование данных и дескрипторы файлов
5.5.1. Вызов fork, файлы и данные
5.5.2. Вызов ехес и открытые файлы
5.6. Завершение процессов при помощи системного вызова halt
5.7. Синхронизация процессов
5.7.1. Системный вызов wait
5.7.2. Ожидание завершения определенного потомка: вызов waitpid
5.8. Зомби-процессы и преждевременное завершение программы
5.9. Командный интерпретатор smallsh
5.10. Атрибуты процесса
5.10.1. Идентификатор процесса
5.10.2. Группы процессов и идентификаторы группы процессов
5.10.3. Изменение группы процесса
5.10.4. Сеансы и идентификатор сеанса
5.10.5. Переменные программного окружения
5.10.6. Текущий рабочий каталог
5.10.7. Текущий корневой каталог
5.10.8. Идентификаторы пользователя и группы
5.10.9. Ограничения на размер файла: вызов ulimit
5.10.10. Приоритеты процессов
Глава 6. Сигналы и их обработка
6.1. Введение
6.1.1. Имена сигналов
6.1.2. Нормальное и аварийное завершение
6.2. Обработка сигналов
6.2.1. Наборы сигналов
6.2.2. Задание обработчика сигналов: вызов sigaction
6.2.3. Сигналы и системные вызовы
6.2.4. Процедуры sigsetjmp и siglongjmp
6.3. Блокирование сигналов
6.4. Посылка сигналов
6.4.1. Посылка сигналов другим процессам: вызов kill
6.4.2. Посылка сигналов самому процессу: вызовы sigraise и alarm
6.4.3. Системный вызов pause
6.4.4. Системные вызовы sigpending и sigsuspend
Глава 7. Межпроцессное взаимодействие при помощи программных каналов
7.1. Каналы
7.1.1. Каналы на уровне команд
7.1.2. Использование каналов в программе
7.1.3. Размер канала
7.1.4. Закрытие каналов
7.1.5. Запись и чтение без блокирования
7.1.6. Использование системного вызова select для работы с несколькими каналами
7.1.7. Каналы и системный вызов ехес
7.2. Именованные каналы, или FIFO
7.2.1. Программирование при помощи каналов FIFO
Глава 8. Дополнительные методы межпроцессного взаимодействия
8.1. Введение
8.2. Блокировка записей
8.2.1. Мотивация
8.2.2. Блокировка записей при помощи вызова fcntl
8.3. Дополнительные средства межпроцессного взаимодействия
8.3.1. Введение и основные понятия
8.3.2. Очереди сообщений
8.3.3. Семафоры
8.3.4. Разделяемая память
8.3.5. Команды ipcs и ipcrm
Глава 9. Терминал
9.1. Введение
9.2. Терминал UNIX
9.2.1. Управляющий терминал
9.2.2. Передача данных
9.2.3. Эхо-отображение вводимых символов и опережающий ввод с клавиатуры
9.2.4. Канонический режим, редактирование строки и специальные символы
9.3. Взгляд с точки зрения программы
9.3.1. Системный вызов fdopen
9.3.2. Системный вызов fdread
9.3.3. Системный вызов fdwrite
9.3.4. Функции ttyname и isatty
9.3.5. Изменение свойств терминала: структура termios
9.3.6. Параметры MIN и TIME
9.3.7. Другие системные вызовы для работы с терминалом
9.3.8. Сигнал разрыва соединения
9.4. Псевдотерминалы
9.5. Пример управления терминалом: программа tscript
Глава 10.Сокеты
10.1. Введение
10.2. Типы соединения
10.3. Адресация
10.3.1. Адресация Internet
10.3.2. Порты
10.4. Интерфейс сокетов
10.4.1. Создание сокета
10.5. Программирование в режиме TCP-соединения
10.5.1. Связывание
10.5.2. Включение приема TCP-соединений
10.5.3. Прием запроса на установку TCP-соединения
10.5.4. Подключение клиента
10.5.5. Пересылка данных
10.5.6. Закрытие TCP-соединения
10.6. Программирование в режиме пересылок UDP-дейтаграмм
10.6.1. Прием и передача UDP-сообщений
10.7. Различия между двумя моделями
Глава 11. Стандартная библиотека ввода/вывода
11.1. Введение
11.2. Структура TFILE
11.3. Открытие и закрытие потоков: процедуры fopen и fclose
11.4. Посимвольный ввод/вывод: процедуры getc и putc
11.5. Возврат символов в поток: процедура ungetc
11.6. Стандартный ввод, стандартный вывод и стандартный вывод диагностики
11.7. Стандартные процедуры опроса состояния
11.8. Построчный ввод и вывод
11.9. Ввод и вывод бинарных данных: процедуры fread и fwrite
11.10. Произвольный доступ к файлу: процедуры fseek, rewind и ftell
11.11. Форматированный вывод: семейство процедур printf
11.12. Форматированный ввод: семейство процедур scanf
11.13. Запуск программ при помощи библиотек стандартного ввода/вывода
11.14. Вспомогательные процедуры
11.14.1. Процедуры freopen и fdopen
11.14.2. Управление буфером: процедуры setbuf и setvbuf
Глава 12. Разные дополнительные системные вызовы и библиотечные процедуры
12.1. Введение
12.2. Управление динамическим распределением памяти
12.3. Ввод/вывод с отображением в память и работа с памятью
12.4. Время
12.5. Работа со строками и символами
12.5.1. Семейство процедур strings
12.5.2. Преобразование строк в числовые значения
12.5.3. Проверка и преобразование символов
12.6. Дополнительные средства
12.6.1. Дополнение о сокетах
12.6.2. Потоки управления
12.6.3. Расширения режима реального времени
12.6.4. Получение параметров локальной системы
12.6.5. Интернационализация
12.6.6. Математические функции
12.6.7. Работа с портами ввода вывода
Глава 13. Задачи с решениями
13.1. Введение
13.2. Обработка текста
13.3. Бинарные файлы
13.4. Каталоги
13.5. Файловые системы
13.6. Файловая система proc
13.7. Управление файлами
13.8. Управление процессами
13.9. Программные каналы
13.10. Управление терминалом
13.11. Дата и время
13.12. Генератор лексических анализаторов lex
Приложение 1. Коды ошибок переменной linuxerror и связанные с ними сообщения
Введение
Список кодов и сообщений об ошибках
Приложение 2. История UNIX
Основные стандарты
Приложение 3. Модуль stdio
Приложение 4. Замечания о компиляции во Free Pascal 2.0
Литература