| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
WinAPI. Функции работы с файлами. Часть 1
WinAPI. Функции работы с файлами. Часть 1:
В этом разделе я начну описывать все известные мне WinAPI функции. Возможно, эти статьи у тебя будут лежать в компьютере вместо хелпа. Сегодня нам предстоит увидеть функции для работы с файлами. Хотя они немного устарели и Microsoft требует использования более новых, я всё же их опишу. А вдруг ты будешь читать старые исходники и наткнешься на них. А если честно, я иногда использую эти функции, потому что они будут ещё долго существовать в Windows для совместимости со старыми прогами. _lopen Эта функция открывает существующий файл и устанавливает позицию чтения в самое начало. Функция устарела и вместо неё желательно использовать CreateFile (рассмотрим, но в другой раз). Существует в: Win16, Win32, Win NT Для С/С++ объявлена в winbase.h. Для Delphi в модуле windows. Объявление: Для С/С++ HFILE _lopen( LPCSTR lpPathName, // Указатель на строку с именем файла int iReadWrite // Тип доступа ); Для Delphi function _lopen( const lpPathName: LPCSTR; // Указатель на строку с именем файла iReadWrite: Integer // Тип доступа ): HFILE; stdcall; Тип доступа может быть:
Если ты хочешь открыть файл с разделяемым доступом, т.е. несколько пользователей смогут открывать один и тот же файл одновременно, то этот параметр сможет принимать значения:
Если функция выполнена успешно, то она возвращает указатель на открытый файл. Если произошла ошибка, то функция вернёт HFILE_ERROR. Для получения более полной информации о происшедшей ошибке нужно вызвать функцию GetLastError (вернуть последнюю ошибку). Пример: _lopen('c:Filename', OF_READWRITE); _lcreat Функция создаёт и сразу открывает новый файл. Функция устарела и вместо неё желательно использовать CreateFile (рассмотрим, но в другой раз). Существует в: Win16, Win32, Win NT Для С/С++ объявлена в winbase.h. Для Delphi в модуле windows. Объявление: Для С/С++
HFILE _lcreat(
LPCSTR lpPathName, // Указатель на имя создаваемого файла
int iAttribute // Атрибуты файла
);
Для Delphi
function _lcreat(
const lpPathName: LPCSTR;// Указатель на имя создаваемого файла
iAttribute: Integer // Атрибуты файла
): HFILE; stdcall;
Атрибуты файла могут быть:
Если функция выполнена успешно, то она возвращает указатель на открытый файл. Если произошла ошибка, то функция вернёт HFILE_ERROR. Для получения более полной информации о происшедшей ошибке нужно вызвать функцию GetLastError (вернуть последнюю ошибку). Пример: _creat('c:Filename', 0); _lread, _hread Функция читает данные из открытого файла. Функция устарела и вместо неё желательно использовать ReadFile (рассмотрим, но в другой раз). Существует в: Win16, Win32, Win NT Для С/С++ объявлена в winbase.h. Для Delphi в модуле windows. Объявление: Для С/С++
long _hread(
HFILE hFile, // Указатель на открытый с помощью _lopen файл
LPVOID lpBuffer, // указатель на буфер, куда нужно прочитать
long lBytes // длина буфера в байтах
);
или
UINT _lread(
HFILE hFile,
LPVOID lpBuffer,
UINT uBytes
);
Для Delphi
function _hread(
hFile: HFILE; // Указатель на открытый с помощью _lopen файл
lpBuffer: Pointer; // указатель на буфер, куда нужно прочитать
lBytes: Longint // длина буфера в байтах
): Longint;
или
function _lread(
hFile: HFILE;
lpBuffer: Pointer;
uBytes: UINT
): UINT; stdcall;
Как видишь, объявлено две функции _lread и _hread. Отличаются они только размерностью параметров. Функция возвращает количество реально прочитанных из файла данных. Если произошла ошибка, то функция вернёт HFILE_ERROR. Для получения более полной информации о происшедшей ошибке нужно вызвать функцию GetLastError (вернуть последнюю ошибку). Пример: _lread(f, buffer, sizeof(buffer)); _lwrite, _hwrite Функция записывает данные в открытый файл. Функция устарела и вместо неё желательно использовать WriteFile (рассмотрим, но в другой раз). Существует в: Win16, Win32, Win NT Для С/С++ объявлена в winbase.h. Для Delphi в модуле windows. Объявление: Для С/С++
UINT _lread(
HFILE hFile, // Указатель на открытый с помощью _lopen файл
LPVOID lpBuffer, // указатель на буфер, который нужно записать
UINT uBytes // длина буфера в байтах
);
или
long _hwrite(
HFILE hFile,
LPCSTR lpBuffer,
long lBytes
);
Для Delphi
function _lwrite(
hFile: HFILE; // Указатель на открытый с помощью _lopen файл
const lpBuffer: LPCSTR; // указатель на буфер, который нужно записать
uBytes: UINT // длина буфера в байтах
): UINT;
или
function _hwrite(
hFile: HFILE;
lpBuffer: LPCSTR;
lBytes: Longint
): Longint;
Как видишь, объявлено две функции _lwrite и _hwrite. Отличаются они только размерностью параметров. Функция возвращает количество реально записанных в файл данных. Если произошла ошибка, то функция вернёт HFILE_ERROR. Для получения более полной информации о происшедшей ошибке нужно вызвать функцию GetLastError (вернуть последнюю ошибку). Пример: _hwrite(f, buffer, sizeof(buffer)); _llseek Функция перемещает позицию чтения/записи в открытом файле. Функция устарела и вместо неё желательно использовать SetFilePointer (рассмотрим, но в другой раз). Существует в: Win16, Win32, Win NT Для С/С++ объявлена в winbase.h. Для Delphi в модуле windows. Объявление: Для С/С++
LONG _llseek(
HFILE hFile, // Указатель на открытый с помощью _lopen файл
LONG lOffset, // Количество байт, на которые нужно передвинутся
int iOrigin // Позиция, от которой нужно двигаться.
);
Для Delphi
function _llseek(
hFile: HFILE; // Указатель на открытый с помощью _lopen файл
lOffset: Longint; // Количество байт, на которые нужно передвинутся
iOrigin: Integer // Позиция, от которой нужно двигаться.
): Longint; stdcall;
Функция возвращает новую позицию от начала файла. Если произошла ошибка, то функция вернёт HFILE_ERROR. Для получения более полной информации о происшедшей ошибке нужно вызвать функцию GetLastError (вернуть последнюю ошибку). iOrigin может принимать значения:
Пример: _llseek(f, 10, FILE_END); В этом примере позиция будет установлена на десять байт до конца файла. _lclose Функция закрывает открытый ранее файл. Функция устарела и вместо неё желательно использовать CloseHandle (рассмотрим, но в другой раз). Существует в: Win16, Win32, Win NT Для С/С++ объявлена в winbase.h. Для Delphi в модуле windows. Объявление: Для С/С++
HFILE _lclose(
HFILE hFile, // Указатель на открытый с помощью _lopen файл
);
Для Delphi
function _lclose(
hFile: HFILE; // Указатель на открытый с помощью _lopen файл
): HFILE; stdcall;
Если файл закрылся, то возвращается ноль. Если произошла ошибка, то функция вернёт HFILE_ERROR. Для получения более полной информации о происшедшей ошибке нужно вызвать функцию GetLastError (вернуть последнюю ошибку). Пример: _hclose(f); Пример на Delphi с использованием сегодняшних функций. var
f:HFILE;
a:array [0..5] of char; //массив из пяти символов
begin
f:=_lopen('c:1.txt',OF_READWRITE);//Открыть файл
_lread(f,@a,5); //Прочитать пять символов
_llseek(f, 0, FILE_BEGIN);//Вернутся на начало файла
_lwrite(f,'VR-online',9); //Записать в файл 9 символов
_lClose(f); //Закрыть файл
end;
Рубрика: Программирование на WinAPI
HTML 5: пять вещей вызывающих особый интер....
HTML 5 — это грядущее обновление гипертекстового языка разметки, основного способа создания контента для размещения его во всемирной паутине. Разработка HTML остановилась в 1999 году, на версии HTML 4.01 и с тех пор web-содержимое изменилось так, что текущие спецификации HTML перестали соответствовать сегодняшним требованиям. HTML 5 нацелен на то, чтобы увеличить функциональную совместимость HTML и соответствовать растущим требованиям разнообразного и смешанного web-контента. HTML 5 так же нацелен на устранение недостатков четвертой версии. В этой статье мы взглянем на 5 новых интересных вещей в HTML 5.
Подробнее... |
Рубрика: Html
| Добавлено: 22.12.2008
asp.net: ListView с разных сторон.
Элемент управления ListView был представлен в .Net Framework 3.5 как замена устаревшему GridView. Новый элемент имеет более расширенный функционал, чем его предшественник, но в тоже время лишен некоторых внутренних механизмов, что впрочем целиком следствие из расширенной универсальности ListView. Среди отличий ListView и GridView можно назвать и гибкую настройку разметки, что позволяет выводить данные не только в табличном виде, но и вообще в любом каком пожелает программист. Благодаря шаблонам ItemTemplate, EditItemTemplate, InsertItemTeplate можно настроить внешний вид при любом из состояний ListView: редактировании или выборе элемента.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Создание кросс-таб отчета в Stimulsoft Rep....
Компания Стимулсофт предоставляет для разработчиков мощный набор инструментов для создания отчетов для Microsoft Visual Studio .Net 2005 и 2008; эти инструменты доступны как для Windows Forms, так и для Web Forms. Это генератор отчетов Stimulsoft Reports.Net. Генератор отчетов Stimulsoft Reports.Net имеет ряд особенностей: простая работа с дизайнером отчетов, полная поддержка экспорта в PDF, Word, Excel и многие другие форматы. Crystal Report и Microsoft Reporting Service – очень хорошие программные продукты для повседневной работы, но, если Вам необходимо создать отчеты с поддержкой кросс-табов, drill down, Ajax, штрих-кодов и возможностью подключения одновременно более одного источника данных, то Stimulsoft Reports.Net поможет Вам сэкономить массу времени. Также, данный генератор отчетов позволяет пользователям создавать свои собственные отчеты любой сложности. И все эти особенности делают Stimulsoft Reports.Net хорошим выбором в сфере программных продуктов для Business Intelligence.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Остальные статьи: |
Цитата дня (все,добавить):
|
Realcoding.NET
© 2003-2008 |
Контакты |
Реклама на сайте
|