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


Функция RtlStringCbLengthA (ntstrsafe.h)

Функции RtlStringCbLengthW и RtlStringCbLengthA определяют длину предоставленной строки в байтах.

Синтаксис

NTSTRSAFEDDI RtlStringCbLengthA(
  [in] STRSAFE_PCNZCH psz,
  [in] size_t         cbMax,
       size_t         *pcbLength
);

Параметры

[in] psz

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

[in] cbMax

Максимально допустимое число байтов в буфере, на которое указывает psz, включая завершающий символ NULL.

Для строк Юникода максимальное число байтов равно NTSTRSAFE_MAX_CCH * sizeof(WCHAR).

Для строк ANSI максимальное число байтов равно NTSTRSAFE_MAX_CCH * sizeof(char).

pcbLength

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

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

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

Код возврата Описание
STATUS_SUCCESS
Это состояние успешного выполнения означает, что строка в psz не имеет значения NULL, а длина строки (включая завершающий символ NULL) меньше или равна символам cbMax .
STATUS_INVALID_PARAMETER
Это состояние ошибки означает, что значение в psz равно NULL, cbMax больше NTSTRSAFE_MAX_CCH * sizeof(TCHAR) или psz длиннее cbMax.

Комментарии

Вместо strlen следует использовать RtlStringCbLengthW и RtlStringCbLengthA. Используйте эти функции, чтобы убедиться, что строка не превышает заданную длину в байтах. Если это условие выполнено, RtlStringCbLengthW и RtlStringCbLengthA возвращают текущую длину строки в байтах, не включая байты, используемые для завершающего символа NULL.

Используйте RtlStringCbLengthW для обработки строк Юникода и RtlStringCbLengthA для обработки строк ANSI. Используемая форма зависит от данных, как показано в следующей таблице.

Строковый тип данных Строковый литерал Функция
WCHAR L"string" RtlStringCbLengthW
char Строка RtlStringCbLengthA
 

Дополнительные сведения о безопасных строковых функциях см. в разделе Использование безопасных строковых функций.

Требования

Требование Значение
Минимальная версия клиента Доступно в Windows XP с пакетом обновления 1 (SP1) и более поздних версиях Windows.
Целевая платформа Персональный компьютер
Верхняя часть ntstrsafe.h (включая Ntstrsafe.h)
Библиотека Ntstrsafe.lib
IRQL Любое значение, если строки, которыми осуществляется управление, всегда находятся в памяти, в противном случае PASSIVE_LEVEL

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

RtlStringCchLength