Функция StringCchPrintfA (strsafe.h)
Записывает отформатированные данные в указанную строку. Размер целевого буфера предоставляется функции, чтобы убедиться, что она не записывает в конец этого буфера.
StringCchPrintf является заменой следующих функций:
Синтаксис
STRSAFEAPI StringCchPrintfA(
[out] STRSAFE_LPSTR pszDest,
[in] size_t cchDest,
[in] STRSAFE_LPCSTR pszFormat,
...
);
Параметры
[out] pszDest
Тип: LPTSTR
Буфер назначения, который получает отформатированную строку, завершающуюся значением NULL, созданную из pszFormat и его аргументов.
[in] cchDest
Тип: size_t
Размер целевого буфера в символах. Это значение должно быть достаточно большим, чтобы вместить последнюю отформатированную строку плюс 1, чтобы учесть завершающий символ NULL. Максимально допустимое число символов — STRSAFE_MAX_CCH.
[in] pszFormat
Тип: LPCTSTR
Строка формата. Эта строка должна быть завершена значением NULL. Дополнительные сведения см. в синтаксисе спецификации формата.
...
Аргументы, которые необходимо вставить в строку pszFormat.
Возвращаемое значение
Тип: HRESULT
Эта функция может возвращать одно из следующих значений. Настоятельно рекомендуется использовать макросы SUCCEEDED и FAILED макросы для проверки возвращаемого значения этой функции.
Возвращаемый код | Описание |
---|---|
|
Для копирования результата достаточно места для копирования в pszDest без усечения, а буфер завершается значением NULL. |
|
Значение в cchDest равно 0 или больше STRSAFE_MAX_CCH. |
|
Операция копирования завершилась ошибкой из-за нехватки буферного пространства. Целевой буфер содержит усеченную, завершаемую null версию предполагаемого результата. В ситуациях, когда усечение приемлемо, это может не обязательно рассматриваться как условие сбоя. |
Обратите внимание, что эта функция возвращает значение HRESULT, в отличие от функций, которые он заменяет.
Замечания
По сравнению с функциями, которые он заменяет, StringCchPrintf обеспечивает дополнительную обработку буферов в коде. Низкая обработка буфера связана со многими проблемами безопасности, включающими переполнение буфера. StringCchPrintf всегда завершает буфер назначения ненулевой длины.
Поведение не определено, если строки, на которые указывает pszDest, pszFormatили любые строки аргументов перекрываются.
Ни pszFormat, ни pszDest не должны быть NULL. См. StringCchPrintfEx, если требуется обработка значений указателя строки NULL.
StringCchPrintf можно использовать в универсальной форме или в более конкретных формах. Тип данных строки определяет форму этой функции, которую следует использовать.
Тип данных строки | Строковый литерал | Функция |
---|---|---|
char | "string" | StringCchPrintfA |
TCHAR | TEXT("string") | StringCchPrintf |
WCHAR | L"string" | StringCchPrintfW |
Примеры
В следующем примере показано простое использование StringCchPrintfс четырьмя аргументами.
TCHAR pszDest[30];
size_t cchDest = 30;
LPCTSTR pszFormat = TEXT("%s %d + %d = %d.");
TCHAR* pszTxt = TEXT("The answer is");
HRESULT hr = StringCchPrintf(pszDest, cchDest, pszFormat, pszTxt, 1, 2, 3);
// The resultant string at pszDest is "The answer is 1 + 2 = 3."
Заметка
Заголовок strsafe.h определяет StringCchPrintf как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОДа. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, не зависящим от кодирования, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.
Требования
Требование | Ценность |
---|---|
минимальные поддерживаемые клиентские | Windows XP с пакетом обновления 2 (SP2) [классические приложения | Приложения UWP] |
минимальный поддерживаемый сервер | Windows Server 2003 с пакетом обновления 1 (SP1) [классические приложения | Приложения UWP] |
целевая платформа | Виндоус |
заголовка | strsafe.h |
См. также
Справочник