• Наиболее примечательным внешним различием между V7 ls
и современной ls
является трактовка опций -а
и -l
. У версии V7 значительно меньше опций, чем у современных версий; заметным недостатком является отсутствие рекурсивной опции -R
.
• Управление flist
является чистым способом использования ограниченной памяти архитектуры PDP-11, предоставляя в то же время как можно больше сведений, struct lbuf
хорошо извлекает нужные сведения из struct stat
; это значительно упрощает код. Код для вывода девяти битов доступа компактен и элегантен.
• Некоторые части ls
используют удивительно маленькие лимиты, такие, как верхняя граница числа файлов в 1024 или размер буфера в makename()
в 100.
Упражнения
1. Рассмотрите функцию getname()
. Что случится, если запрошенный ID равен 256, а в /etc/passwd
есть следующие две строки, в этом порядке:
joe:xyzzy:2160:10:Joe User:/usr/joe:/bin/sh
jane:zzyxx:216:12:Jane User:/usr/jane:/bin/sh
2. Рассмотрите функцию makename()
. Может ли она использовать sprintf()
для составления имени? Почему может или почему нет?
3. Являются ли строки 319–320 в readdir()
действительно необходимыми?
4. Возьмите программу stat
, которую вы написали в качестве упражнения в «Упражнениях» к главе 6. Добавьте функцию nblock()
из V7 ls
и выведите результаты вместе с полем st_blocks
из struct stat
. Добавьте видимый маркер, когда они различны.
5. Как бы вы оценили V7 ls
по ее использованию malloc()
? (Подсказка: как часто вызывается free()
? Где ее следовало бы вызвать?)
6. Как вы оценили бы ясность кода V7 ls
? (Подсказка: сколько там комментариев?)
7. Очертите шаги, которые нужно было бы сделать, чтобы адаптировать V7 ls
для современных систем.
Глава 8
Файловые системы и обходы каталогов
Данная глава завершает обсуждение файловых систем и каталогов Linux (и Unix). Сначала мы опишем, как к логическому пространству имен файловой системы добавляется (и удаляется) раздел диска, содержащий файловую систему, таким образом, что в общем пользователю не нужно ни знать, ни заботиться о месте физического размещения файла, вместе с API для работы с файловыми системами
Затем мы опишем, как перемещаться по иерархическому пространству имен файлов, как получать полный путь текущего рабочего каталога и как без труда обрабатывать произвольные иерархии (деревья) каталогов, используя функцию nftw()
. Наконец, мы опишем специализированный, но важный системный вызов chroot()
.
8.1. Монтирование и демонтирование файловых систем
Унифицированное иерархическое пространство имен файлов является большим достоинством дизайна Linux/Unix. Данный раздел рассматривает, как административные файлы, команды и операционная система объединяются для построения пространства имен из отдельных физических устройств, содержащих данные и служебные данные файлов.
8.1.1. Обзор основ
В главе 5 «Каталоги и служебные данные файлов», были представлены индексы для служебных данных файлов и описано, как элементы каталогов связывают имена файлов с индексами В ней также были описаны разделы и файловые системы, и вы видели, что прямые ссылки ограничены работой в пределах одной файловой системы, поскольку каталоги содержат лишь номера индексов, а последние не уникальны среди всего набора использующихся файловых систем.
Помимо индексов и блоков данных, файловые системы содержат также одну или более копий
Обеспечение доступа к разделу, содержащему файловую систему, называется
Эти две задачи выполняются программами mount
и umount
[так], названными по соответствующим системным вызовам. У системного вызова mount()
каждой системы Unix свой, отличный интерфейс. Поскольку монтирование и демонтирование считаются проблемой реализации, POSIX намеренно не стандартизует эти системные вызовы
Вы монтируете файловую систему в каталог; такой каталог называется