|
| БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО! |
|
|
Creating and Opening Files
You can use the CreateFile function to create a new file or open an existing file. You must specify the filename, preferred access, share mode, creation instructions, and attributes.
In the following example, CreateFile opens an existing file for reading.
HANDLE hFile; hFile = CreateFile("MYFILE.TXT", // open MYFILE.TXT GENERIC_READ, // open for reading FILE_SHARE_READ, // share for reading NULL, // no security OPEN_EXISTING, // existing file only FILE_ATTRIBUTE_NORMAL, // normal file NULL); // no attr. template if (hFile == INVALID_HANDLE_VALUE) {
ErrorHandler("Could not open file."); /* process error */ }
In this example, CreateFile succeeds only if a file named MYFILE.TXT already exists in the current directory. An application should check the return value of CreateFile before attempting to use the handle to access the file. If an error occurs, the application should use the GetLastError function to get extended error information and respond accordingly. A file must be closed before it can be deleted. The following lines close and delete the MYFILE.TXT file.
CloseHandle(hFile); DeleteFile("MYFILE.TXT");
In the following example, CreateFile creates a new file and opens it for writing.
HANDLE hFile; hFile = CreateFile("MYFILE.TXT", // create MYFILE.TXT GENERIC_WRITE, // open for writing 0, // do not share NULL, // no security CREATE_ALWAYS, // overwrite existing FILE_ATTRIBUTE_NORMAL | // normal file FILE_FLAG_OVERLAPPED, // asynchronous I/O NULL); // no attr. template
if (hFile == INVALID_HANDLE_VALUE) { ErrorHandler("Could not open file."); // process error }
In addition to the standard attributes (read only, hidden, system, and so on), you can also specify security attributes by including a pointer to a SECURITY_ATTRIBUTES structure as the fourth parameter. However, the underlying file system must support security for these attributes for them to have any effect. For more information about security, see Security.
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
Создание Файлов и Открытия
Вы можете использовать функцию CreateFile, чтобы создавать новый файл или открывать существующий файл. Вы должны определить filename, предпочевший доступ, акционерный способ, инструкции создания, и атрибуты.
В следующем примере, CreateFile открывает существующий файл для чтения.
ПРООПЕРИРУЙТЕ hFile; hFile = CreateFile("MYFILE.TXT", // Открытый MYFILE.TXT GENERIC_READ, // открытый для чтения FILE_SHARE_READ, // акция для чтения НЕДЕЙСТВИТЕЛЬНАЯ, // никакая безопасность OPEN_EXISTING, // существующий файл только FILE_ATTRIBUTE_NORMAL, // нормальный файловый НЕДЕЙСТВИТЕЛЬНЫЙ); // никакой attr. шаблон если (hFile == INVALID_HANDLE_VALUE) {
ErrorHandler("Could НЕ открытый файл."); /* ошибка процесса */ }
В этом примере, CreateFile добивается успеха только если файл называл бы MYFILE.TXT уже существует в текущем директории. Приложение должно проверять обратную величину CreateFile перед попыткой использовать ручку, чтобы иметь доступ к файлу. Если ошибка происходит, приложение должно использовать функцию GetLastError, чтобы расширять информацию ошибки и отвечать соответственно. Файл должен быть закрыт прежде, чем он может быть удален. Следующие строки закрывают и удаляют файл MYFILE.TXT.
CloseHandle(hFile); DeleteFile("MYFILE.TXT");
В следующем примере, CreateFile создает новый файл и открывает это для записи.
ПРООПЕРИРУЙТЕ hFile; hFile = CreateFile("MYFILE.TXT", // Создавать MYFILE.TXT GENERIC_WRITE, // открытый для записи 0, // не распространять НЕДЕЙСТВИТЕЛЬНЫЙ, // никакая безопасность CREATE_ALWAYS, // перезаписывать существовать FILE_ATTRIBUTE_NORMAL | // нормальный файл FILE_FLAG_OVERLAPPED, // асинхронный В/В НЕДЕЙСТВИТЕЛЬНЫЙ); // никакой attr. шаблон
если (hFile == INVALID_HANDLE_VALUE) { ErrorHandler("Could не открытый файл."); // ошибка процесса }
Дополнительно к стандартным атрибутам (прочитанное только, спрятанное, система, и так далее), Вы можете также определить атрибуты безопасности включая указатель в структуру SECURITY_ATTRIBUTES как четвертый параметр. Тем не менее, основная файловая система должна поддержать безопасность для этих атрибутов для них, чтобы иметь любой эффект. Более подробно о безопасности, смотри Безопасность.
|
|
|
|
| |