Linux программирование в примерах
Linux программирование в примерах читать книгу онлайн
В книге рассмотрены вопросы, связанные с программированием под Linux: файловый ввод/вывод, метаданные файлов, основы управления памятью, процессы и сигналы, пользователи и группы, вопросы интернационализации и локализации, сортировка, поиск и многие другие. Много внимания уделено средствам отладки, доступным под GNU Linux. Все темы иллюстрируются примерами кода, взятого из V7 UNIX и GNU. Эта книга может быть полезна любому, кто интересуется программированием под Linux.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
• Системные вызовы
read()
write()
lseek()
• Для синхронного ввода/вывода предусмотрены дополнительные флаги для
open()
write()
read()
fsync()
fdatasync()
• Системные вызовы
truncate()
ftruncate()
Упражнения
1. Используя лишь
open()
read(),
write()
close()
copy
2. Усовершенствуйте программу
copy
-
copy - -
3. Просмотрите страничку справки для proc(5) на системе GNU/Linux. В частности, посмотрите подраздел
fd
ls -l /dev/fd
/proc/self/fd
/dev/stdin
cat
/dev/fd
4. Даже если вы пока этого не понимаете, постарайтесь скопировать сегмент кода из V7
cat.c
struct stat
fstat()
ch04-cat.c
cat file >> file
5. (Простое) Предположив наличие
strerror()
perror()
6. Каков результат выполнения '
ulimit -n
7. Напишите простую версию программы
umask
myumask
strtol()
umask
umask()
Откомпилируйте и запустите
myumask
umask
umask
type umask
8. Измените простую программу
copy
open()
O_SYNC
time
9. Мы сказали, что для
ftruncate()
10. Напишите программу
truncate
truncate <i>длина_файла</i>
Глава 5
Каталоги и служебные данные файлов
Данная глава продолжает подъем по кривой обучения до следующего плато: понимания каталогов и информации о файлах.
В данной главе мы исследуем то, как информация хранится в каталоге, как читаются, создаются и удаляются сами каталоги, какая информация о файлах доступна и как ее получить. Наконец, мы рассмотрим другие способы обновления служебных данных файлов, таких, как владелец, группа, права доступа и время доступа и изменения файла.
5.1. Просмотр содержимого каталога
Все Unix-системы, включая Linux, используют для хранения файловой информации на диске один и тот же концептуальный дизайн. Хотя в реализации дизайна есть значительные вариации, интерфейс на уровне С остается постоянным, давая возможность писать переносимые программы, которые компилируются и запускаются на многих различных системах.
5.1.1. Определения
Рис. Copyright 1997-2004 © J.D. «Illiad» Frazer. Использовано по разрешению, http://www.userfriendly.org
Мы начнем обсуждение с определения нескольких терминов.
Раздел (partition)
Единица физического хранилища. Физические разделы обычно являются либо частями диска, либо целым диском. Современные системы дают возможность создавать из нескольких физических логические разделы.
Файловая система (filesystem)
Раздел (физический или логический), содержащий данные файла и служебные данные (metadata), информацию о файлах (в противоположность содержимому файла, которое является информацией в файле). Такие служебные данные включают владельца файла, права доступа, размер и т.д., а также информацию, использующуюся операционной системой при поиске содержимого файла. Файловые системы размещаются «в» разделах (соотношение одни к одному) посредством записи в них стандартной информации. Это осуществляется программой уровня пользователя, такой, как
mke2fs
newfs
mkfs
newfs
Большей частью GNU/Linux и Unix скрывают наличие файловых систем и разделов. (Дополнительные подробности приведены в разделе 8.1 «Монтирование и демонтирование файловых систем».) Доступ ко всему осуществляется через пути, безотносительно к тому, на каком диске расположен файл. (Сравните это с почти любой коммерческой операционной системой, такой, как OpenVMS, или с поведением по умолчанию любой системы Microsoft.)