Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
ТЕХНОЛОГИИ ДОСТ... 65300
Имитационное мо... 59116
Реклама
Сейчас на сайте
Гостей: 14
На сайте нет зарегистрированных пользователей

Пользователей: 13,104
новичок: oseose
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

База данных - словарь терминов на Delphi + Пояснительная записка
Принадлежит ли точка пересечению двух окружностей на Turbo Pascal + Отче...
Информационная система - транспортный парк на Turbo Pascal (База данных)...

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Модель 4.4BSD
Разработчики реализации интерфейса vnode/vfs для 4.4BSD [7] попытались преодолеть проблемы варианта SunOS/SVR4 путем улучшения функционирования операции подстановки при помощи встраивания в нее возможностей интерфейса namei ОС 4.3BSD (и GFS).


Новая версия позволила производить блокировку объектов vnode сразу на время проведения нескольких операций и передавать информацию о состоянии между зависящими друг от друга действиями многоступенчатых системных вызовов.



Просмотр путей в системе 4.4BSD производится при помощи процедуры
namei()




которая, в свою очередь, вызывает процедуру поиска vnode текущего каталога. Для преобразования ей передается полное имя пути. Зависимая от файловой системы процедура подстановки может преобразовывать сразу один или более компонентов в одиночный вызов, но не обладает возможностью пересечения точки монтирования. Некоторые реализации процедуры могут преобразовать одновременно лишь один компонент (например, в файловой системе NFS), в то время как реализации s5fs или ufs способны преобразовывать имя пути целиком (если в имени не встречается точка монтирования). После достижения такой точки функция namei() производит необходимые действия и передает оставшуюся часть имени пути следующей операции преобразования.
Аргументы функции подстановки собраны в структуру nameidata. Структура содержит несколько дополнительных полей для передачи информации о состоянии и для внешних данных, возвращаемых функцией. Она может передаваться другим операциям, таким как create или symlink, позволяя взаимосвязанным задачам использовать данные без занесения переменных в стек.



Одно из полей структуры nameidata содержит обоснование преобразования полных имен. Если производится создание или удаление файла, то последняя по счету операция заблокирует объект vnode родительского каталога.

Функция также вернет дополнительную информацию через структуру nameidata, например, о расположении файла в текущем каталоге (если файл был обнаружен), о первой свободной ячейке каталога (для дальнейшего создания файла). Затем структура nameidata передается операциям create или delete. Так как родительский каталог остается заблокированным функцией преобразования, ее содержимое не может быть изменено, следовательно, функциям создания или удаления файла не придется повторно выполнять последнюю итерацию поиска. После завершения выполнения операции произойдет освобождение родительского каталога.
Иногда после завершения операции ядро не разрешает производить создание или удаление файла (например, если вызывающий процесс не обладает необходимыми полномочиями). В этом случае ядро загружает операцию abortop для сброса блокировки родительского каталога.
Несмотря на то, что интерфейс запоминает полученную информацию, и блокировка может проводиться сразу на несколько операций, действия по установке и освобождению объектов блокировки производятся на уровне, зависящем от файловой системы. Таким образом, интерфейс может поддерживать одновременно файловые системы, которые могут как сохранять, так и не сохранять информацию о состоянии, не производя избыточные действия, если это возможно. Например, в файловой системе с сохранением (такой как NFS) можно не производить блокировку родительского каталога и также отказаться от поиска последнего компонента, если сразу после преобразования имен будут запущены вызовы create или delete.
Основной проблемой такого подхода является последовательность проведения всех операций над каталогом, так как блокировка объекта удерживается на протяжении всей длительности проведения операции, даже в том случае, если процесс приостанавливается в ожидании завершения ввода-вывода. Реализация вызова использует эксклюзивный объект блокировки, запрещающий выполнять параллельно даже операции чтения. В частности, в системах разделения времени это может привести к возникновению больших задержек при доступе к наиболее часто используемым каталогам, таким как / и /etc. Для многопроцессорных систем описанная методика последовательной работы операций является неприемлемой.
Еще одним изменением, внесенным разработчиками новой версии интерфейса vnode/vfs, является поддержка кэша каталогов и смещения последнего, удачного завершившегося поиска имен каждого процесса. Это увеличивает производительность операций, производящих действия над всеми файлами в каталоге. Операция nameiQ использует кэш во время поиска последнего компонента имени. Если родительский каталог совпадает с указанным для предыдущего вызова namei(), поиск начнется от смещения, указанного в кэше (вместо начала каталога).


Интерфейс файловой системы 4.4BSD предлагает и другие интересные возможности, например стековую организацию vnode (stackable vnode) и объединенное монтирование (union mount), которые будут описаны позже
.
Опубликовал katy July 09 2015 11:33:21 · 0 Комментариев · 1116 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Профессиональное ...
Панель случайной ...
LaserTank [Исходн...
FileFind
Win-Prolog 3.618
PHP в примерах
HTMLredaktor
Секреты программи...
Самоучитель C++
Java в примерах -...
Цветной Grid
MxProtector
Шаблон для новост...
ZipTV
Dbgridpack
Песочные часы
BIOS
База данных фильм...
«Философия» прогр...
TMS

Топ загрузок
Приложение Клие... 100505
Delphi 7 Enterp... 89568
Converter AMR<-... 20090
GPSS World Stud... 14465
Borland C++Buil... 12520
Borland Delphi ... 8879
Turbo Pascal fo... 7082
Калькулятор [Ис... 5061
Visual Studio 2... 5016
FreeSMS v1.3.1 3552
Случайные статьи
Как найти резидент...
Небольшие версии
Таблица помогает с...
Моделирование расп...
String expression ...
Функция GraphResul...
Элементы applet и ...
тег структуры
Варианты дисплея с...
Популярность исход...
Выражения в списке...
ТЕХНОЛОГИИ ДОСТУПА...
Запрос продуктов д...
Invalid FOR contro...
Создание в среде D...
Связываемые таблиц...
База знаний - книги
Сортировка
Списки потомков + ...
Запись и чтение ко...
Об описании алгоритма
Текст в ячейках та...
Оригинальная полно...
Коллективное владение
подпись ко всем по...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?