Delphi-Help

  • Increase font size
  • Default font size
  • Decrease font size
Главная Файловый архив Книги СИСТЕМНОЕ ПРОГРАММИРОВАНИЕ В UNIX средствами Free Pascal

Файловый архив
Список категорий Поиск Добавить файл
Подробности закачки
СИСТЕМНОЕ ПРОГРАММИРОВАНИЕ В UNIX средствами Free Pascal

СИСТЕМНОЕ ПРОГРАММИРОВАНИЕ В UNIX средствами Free Pascal

Содержание

 

Предисловие

О книге

Назначение этой книги

Спецификация Х/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

Литература

Данные о файле

Размер 665.57 KB
Скачиваний 799
Автор
Web-сайт

Скачать

Добавить комментарий


Защитный код
Обновить

Авторизация



Счетчики