Ескертпе
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Жүйеге кіруді немесе каталогтарды өзгертуді байқап көруге болады.
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Каталогтарды өзгертуді байқап көруге болады.
Записывает форматированные данные в указанную строку с помощью указателя на список аргументов. Размер целевого буфера предоставляется функции, чтобы убедиться, что она не записывает в конец этого буфера.
StringCchVPrintfEx добавляет к функциям StringCchVPrintf, возвращая указатель на конец конечной строки, а также количество символов, оставшихся неиспользуемыми в этой строке. Флаги также могут передаваться функции для дополнительного элемента управления.
StringCchVPrintfEx является заменой следующих функций:
Синтаксис
STRSAFEAPI StringCchVPrintfExA(
[out] STRSAFE_LPSTR pszDest,
[in] size_t cchDest,
[out, optional] STRSAFE_LPSTR *ppszDestEnd,
[out, optional] size_t *pcchRemaining,
[in] DWORD dwFlags,
[in] STRSAFE_LPCSTR pszFormat,
[in] va_list argList
);
Параметры
[out] pszDest
Тип: LPTSTR
Конечный буфер, который получает отформатированную строку, завершающуюся значением NULL, созданную из pszFormat и argList.
[in] cchDest
Тип: size_t
Размер целевого буфера в символах. Это значение должно быть достаточно большим, чтобы вместить последнюю отформатированную строку плюс 1, чтобы учесть завершающий символ NULL. Максимально допустимое число символов — STRSAFE_MAX_CCH.
[out, optional] ppszDestEnd
Тип: LPTSTR*
Адрес указателя на конец pszDest. Если ppszDestEnd не являетсяNULL, а все данные копируются в целевой буфер, это указывает на конечный символ NULL в конце строки.
[out, optional] pcchRemaining
Тип: size_t*
Количество неиспользуемых символов в pszDest, включая завершающийся символ NULL. Если pcchRemainingNULL, количество не сохраняется или возвращается.
[in] dwFlags
Тип: DWORD
Одно или несколько следующих значений.
[in] pszFormat
Тип: LPCTSTR
Строка формата. Эта строка должна быть завершена значением NULL. Дополнительные сведения см. в синтаксисе спецификации формата.
[in] argList
Тип: va_list
Аргументы, которые необходимо вставить в строку pszFormat.
Возвращаемое значение
Тип: HRESULT
Эта функция может возвращать одно из следующих значений. Настоятельно рекомендуется использовать макросы SUCCEEDED и FAILED макросы для проверки возвращаемого значения этой функции.
| Возвращаемый код | Описание |
|---|---|
|
Было достаточно места для копирования результата в pszDest без усечения, и буфер завершается значением NULL. |
|
Значение в cchDest равно 0 или больше, чем STRSAFE_MAX_CCH, или целевой буфер уже заполнен. |
|
Операция копирования завершилась ошибкой из-за нехватки буферного пространства. В зависимости от значения dwFlags, целевой буфер может содержать усеченную, завершаемую null версию предполагаемого результата. В ситуациях, когда усечение приемлемо, это может не обязательно рассматриваться как условие сбоя. |
Обратите внимание, что эта функция возвращает значение HRESULT, в отличие от функций, которые он заменяет.
Замечания
StringCchVPrintfEx обеспечивает дополнительную обработку буфера в коде. Низкая обработка буфера связана со многими проблемами безопасности, включающими переполнение буфера. StringCchVPrintfEx всегда завершает буфер назначения ненулевой длины.
Дополнительные сведения о va_lists см. в соглашениях, определенных в Stdarg.h.
Поведение не определено, если строки, на которые указывает pszDest, pszFormatили любые строки аргументов перекрываются.
Ни pszFormat, ни pszDest не должны быть null, если флаг STRSAFE_IGNORE_NULLS не указан, в этом случае оба могут быть NULL. Однако ошибка из-за нехватки места может быть возвращена, даже если значения NULL игнорируются.
StringCchVPrintfEx можно использовать в универсальной форме или в более конкретных формах. Тип данных строки определяет форму этой функции, как показано в следующей таблице.
| Тип данных строки | Строковый литерал | Функция |
|---|---|---|
| char | "string" | StringCchVPrintfExA |
| TCHAR | TEXT("string") | StringCchVPrintfEx |
| WCHAR | L"string" | StringCchVPrintfExW |
Заметка
Заголовок strsafe.h определяет StringCchVPrintfEx как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОДа. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, не зависящим от кодирования, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.
Требования
| Требование | Ценность |
|---|---|
| минимальные поддерживаемые клиентские | Windows XP с пакетом обновления 2 (SP2) [классические приложения | Приложения UWP] |
| минимальный поддерживаемый сервер | Windows Server 2003 с пакетом обновления 1 (SP1) [классические приложения | Приложения UWP] |
| целевая платформа | Виндоус |
| заголовка | strsafe.h |
См. также
Справочник