Поделиться через


Функция NtLockFile (ntifs.h)

Подпрограмма NtLockFile запрашивает блокировку диапазона байтов для указанного файла.

Синтаксис

__kernel_entry NTSYSCALLAPI NTSTATUS NtLockFile(
  [in]           HANDLE           FileHandle,
  [in, optional] HANDLE           Event,
  [in, optional] PIO_APC_ROUTINE  ApcRoutine,
  [in, optional] PVOID            ApcContext,
  [out]          PIO_STATUS_BLOCK IoStatusBlock,
  [in]           PLARGE_INTEGER   ByteOffset,
  [in]           PLARGE_INTEGER   Length,
  [in]           ULONG            Key,
  [in]           BOOLEAN          FailImmediately,
  [in]           BOOLEAN          ExclusiveLock
);

Параметры

[in] FileHandle

Дескриптор для файла, для которого запрашивается блокировка диапазона байтов.

[in, optional] Event

Дескриптор события, созданного вызывающим. Если значение не равно NULL, вызывающий объект переводится в состояние ожидания, пока операция не завершится успешно, после чего событие переходит в состояние Signaled .

[in, optional] ApcRoutine

Указатель на подпрограмму APC, предоставляемую вызывающим объектом, которая выполняется после завершения операции. Может иметь значение NULL.

[in, optional] ApcContext

Указатель на контекст, заданный вызывающим объектом, для подпрограммы APC. Это значение передается в подпрограмму APC при ее выполнении. Может иметь значение NULL.

[out] IoStatusBlock

Указатель на структуру IO_STATUS_BLOCK , содержащую конечное состояние.

[in] ByteOffset

Указатель на переменную, указывающую начальное смещение в байтах диапазона для блокировки.

[in] Length

Указатель на переменную, указывающую длину диапазона для блокировки в байтах.

[in] Key

Значение, назначаемое вызывающей системой, используемое для описания групп связанных блокировок. Это значение должно быть равно нулю.

[in] FailImmediately

Если задано значение TRUE, немедленно возвращается значение , если не удается заблокировать файл. Если задано значение FALSE, дождитесь предоставления запроса на блокировку.

[in] ExclusiveLock

Если задано значение TRUE, блокировка диапазона байтов является монопольной; в противном случае — общая блокировка.

Возвращаемое значение

Подпрограмма NtLockFile возвращает STATUS_SUCCESS или соответствующее значение NTSTATUS. Возможные значения NTSTATUS:

Код возврата Описание
STATUS_INSUFFICIENT_RESOURCES Недостаточно ресурсов для предоставления блокировки диапазона байтов для указанного файла.
STATUS_LOCK_NOT_GRANTED Блокировка диапазона байтов не была предоставлена для указанного файла.

Комментарии

Вызывающие функции NtLockFile должны выполняться в IRQL = PASSIVE_LEVEL и с включенными специальными api ядра**.

Примечание

Если вызов функции NtLockFile выполняется в пользовательском режиме, следует использовать имя "NtLockFile" вместо "ZwLockFile".

Для вызовов из драйверов режима ядра версии NtXxx и ZwXxx подпрограммы Собственные системные службы Windows могут вести себя по-разному, так как они обрабатывают и интерпретируют входные параметры. Дополнительные сведения о связи между версиями подпрограмм NtXxx и ZwXxx см. в статье Использование версий nt и Zw для подпрограмм собственных системных служб**.

Требования

Требование Значение
Минимальная версия клиента Windows 7
Целевая платформа Универсальное
Верхняя часть ntifs.h (включая Ntifs.h, FltKernel.h)
Библиотека NtosKrnl.lib
DLL NtosKrnl.exe
IRQL PASSIVE_LEVEL (см. раздел "Примечания")
Правила соответствия DDI HwStorPortProhibitedDIs, PowerIrpDDis

См. также раздел

ZwUnlockFile