Все о моделировании в Компас-3D LT
   Главная Статьи Файлы Форум Ссылки Категории новостей
Февраль 04 2023 16:14:57   
Навигация
Главная
Статьи
Файлы
FAQ
Форум
Ссылки
Категории новостей
Обратная связь
Фото галерея
Поиск
Разное
Карта Сайта
Популярные статьи
Что необходимо ... 65535
Учимся удалять!... 31028
4.12.1 Професси... 29881
Примеры, синони... 22740
Просмотр готовы... 21435
Декартовы коорд... 21055
FAST (методика ... 20841
содержание - се... 19994
Просмотр готовы... 18101
Работа с инстру... 13879
Сейчас на сайте
Гостей: 1
На сайте нет зарегистрированных пользователей

Пользователей: 9,955
новичок: Logyattella
Друзья сайта
Ramblers Top100
Рейтинг@Mail.ru

Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ по Delphi
Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog
5.5 УКАЗАНИЕ МЕСТА В ФАЙЛЕ, ГДЕ БУДЕТ ВЫПОЛНЯТЬСЯ ВВОД-ВЫВОД — LSEEК
Обычное использование системных функций read и write обеспечивает последовательный доступ к файлу, однако процессы могут использовать вызов системной функции lseek для указания места в файле, где будет производиться ввод-вывод, и осуществления произвольного доступа к файлу. Синтаксис вызова системной функции:
position = lseek(fd, offset, reference);
где fd — дескриптор файла, идентифицирующий файл, offset — смещение в байтах, а reference указывает, является ли значение offset смещением от начала файла, смещением от текущей позиции ввода-вывода или смещением от конца файла. Возвращаемое значение, position, является смещением в байтах до места, где будет начинаться следующая операция чтения или записи. Например, в программе, приведенной на Рисунке 5.10, процесс открывает файл, считывает байт, а затем вызывает функцию lseek, чтобы заменить значение поля смещения в таблице файлов величиной, равной 1023 (с переменной reference, имеющей значение 1), и выполняет цикл. Таким образом, программа считывает каждый 1024-й байт файла. Если reference имеет значение 0, ядро осуществляет поиск от начала файла, а если 2, ядро ведет поиск от конца файла. Функция lseek ничего не должна делать, кроме операции поиска, которая позиционирует головку чтения-записи на указанный дисковый сектор. Для того, чтобы выполнить функцию lseek, ядро просто выбирает значение смещения из таблицы файлов; в последующих вызовах функций read и write смещение из таблицы файлов используется в качестве начального смещения.
#include ‹fcntl.h›
main(argc, argv)
int argc; char *argv[];
{
int fd, skval;
char c;
if (argc != 2) exit();
fd = open(argv[1], O_RDONLY);
if (fd == -1) exit();
while ((skval = read(fd, &c,1 )) == 1) {
printf("char %c\n", c);
skval = lseek(fd, 1023L, 1);
printf("new seek val %d\n", skval);
}
}
Рисунок 5.10. Программа, содержащая вызов системной функции lseek
Комментарии
Нет комментариев.
Добавить комментарий
Пожалуйста залогиньтесь для добавления комментария.
Рейтинги
Рейтинг доступен только для пользователей.

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

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

Пароль



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

Забыли пароль?
Запросите новый здесь.
Случайные статьи
Необычные дуги
4.10 Технология fr...
Ресурс бизнес-проц...
Правила для сущностей
Глава 26. iFinder
Карты памяти
Вспомогательные ...
5.3. Долговременны...
Настройка сетевых ...
ГЛАВА 6. ИСПОЛЬЗО...
3.2.3. Технология ...
2.6.2.3 Формирован...
ССЫЛКИ НА ИСПОЛЬЗУ...
Оценка степени мощ...
4.1. Методы внутре...
Микроэлектроника
Маршруты-невидимки
Общая схема вывода
4.12.3.5 Система с...
2.4.2 Логическое к...
5.12.1 Системная ф...
Идея пятая: Ионосф...
Глава 19. GSM/GPS-...
2.3.2.2 Сигналы зв...
6.2.4 Пространство...
Глава 12. Fortuna...
Video Logic DigiTh...
По законам джунглей
7.4.1. Организаци...
2.6 УПРАЖНЕНИЯ
3.6 Технология E...
3.10 Технологии To...
Код Хемминга
Подсхемы
Навигационные функции
СИСТЕМНЫЕ ОПЕРАЦИИ...
Бенчмаркинг процесса.
2.1. Поведенческие...
6.2.2 Страницы и т...
Непереносимые связи
Мини-чат
Вам необходимо залогиниться.

Нет присланных сообщений.
Copyright © 2009