Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Скидка до 20% на услуги дата-центра. Аренда серверной стойки. Colocation от 1U!

Миграция в облако #SotelCloud. Виртуальный сервер в облаке. Выбрать конфигурацию на сайте!

Виртуальная АТС для вашего бизнеса. Приветственные бонусы для новых клиентов!

Виртуальные VPS серверы в РФ и ЕС

Dedicated серверы в РФ и ЕС

По промокоду CITFORUM скидка 30% на заказ VPS\VDS

VPS/VDS серверы. 30 локаций на выбор

Серверы VPS/VDS с большим диском

Хорошие условия для реселлеров

4VPS.SU - VPS в 17-ти странах

2Gbit/s безлимит

Современное железо!

Книги: [Классика] [Базы данных] [Internet/WWW] [Сети] [Программирование] [UNIX] [Windows] [Безопасность] [Графика] [Software Engineering] [ERP-системы] [Hardware]

     

Системное программирование в UNIX

Кейт Хэвиленд, Дайна Грэй, Бен Салама

Издано:2000, M., ДМК Пресс
Для профессионалов
ISBN: 5-94074-008-1
Мягкий переплет, 368 стр.
Формат: 70x100/16

Начало
Предисловие
Структура книги
[Заказать книгу в магазине "Мистраль"]

Содержание

Предисловие
Соглашения
Благодарности
Глава 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. Системный вызов open
    2.1.3. Создание файла при помощи вызова open
    2.1.4. Системный вызов creat
    2.1.5. Системный вызов close
    2.1.6. Системный вызов read
    2.1.7. Системный вызов write
    2.1.8. Пример copyfile
    2.1.9. Эффективность вызовов read и write
    2.1.10. Вызов Iseek и произвольный доступ
    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. Системные вызовы и переменная errno
    2.4.1. Подпрограмма perror

Глава 3. Работа с файлами
  3.1. Файлы в многопользовательской среде
    3.1.1. Пользователи и права доступа
    3.1.2. Права доступа и режимы файлов
    3.1.3. Дополнительные права доступа для исполняемых файлов
    3.1.4. Маска создания файла и системный вызов umask
    3.1.5. Вызов open и права доступа к файлу
    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. Системный вызов rename
    3.2.4. Символьные ссылки
  3.3. Получение информации о файле: вызовы stat и 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. Структура stat
    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. Доступ к аргументам, передаваемым при вызове ехес
  5.4. Совместное использование вызовов ехес и fork
  5.5. Наследование данных и дескрипторы файлов
    5.5.1. Вызов fork, файлы и данные
    5.5.2. Вызов ехес и открытые файлы
  5.6. Завершение процессов при помощи системного вызова exit
  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. Приоритеты процессов: вызов nice

Глава 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. Посылка сигналов самому процессу: вызовы raise и alarm
    6.4.3. Системный вызов pause

Глава 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. Системный вызов open
    9.3.2. Системный вызов read
    9.3.3. Системный вызов write
    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. Включение приема ТСР-соединений
    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. Структура FILE
  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. Форматированный ввод: семейство процедур scant
  11.13. Запуск программ при помощи библиотеки
         стандартного ввода/вывода
  11.14. Вспомогательные процедуры
    11.14.1. Процедуры freopen и fdореn
    11.14.2. Управление буфером: процедуры setbuf и setvbuf

Глава 12. Разные дополнительные системные
             вызовы и библиотечные процедуры
  12.1. Введение
  12.2. Управление динамическим распределением памяти
  12.3. Ввод/вывод с отображением в память и работа с памятью
  12.4. Время
  12.5. Работа со строками и символами
    12.5.1. Семейство процедур string
    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. Математические функции
Приложение 1. Коды ошибок переменной errno и
                 связанные с ними сообщения
  Введение
  Список кодов и сообщений об ошибках
Приложение 2. История UNIX
  Основные стандарты
  Библиография и дополнительные источники
Алфавитный указатель

Начало
Предисловие
Структура книги
Заказать книгу в магазине "Мистраль"

 

Бесплатный конструктор сайтов и Landing Page

Хостинг с DDoS защитой от 2.5$ + Бесплатный SSL и Домен

SSD VPS в Нидерландах под различные задачи от 2.6$

✅ Дешевый VPS-хостинг на AMD EPYC: 1vCore, 3GB DDR4, 15GB NVMe всего за €3,50!

🔥 Anti-DDoS защита 12 Тбит/с!

VPS в России, Европе и США

Бесплатная поддержка и администрирование

Оплата российскими и международными картами

🔥 VPS до 5.7 ГГц под любые задачи с AntiDDoS в 7 локациях

💸 Гифткод CITFORUM (250р на баланс) и попробуйте уже сейчас!

🛒 Скидка 15% на первый платеж (в течение 24ч)

Новости мира IT:

Архив новостей

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 7861149
Пресс-релизы — pr@citforum.ru
Обратная связь
Информация для авторов
Rambler's Top100 TopList This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2019 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...