_cprintf_s, _cprintf_s_l, _cwprintf_s, _cwprintf_s_l
布局和输出到控件中。 这些是 _cprintf, _cprintf_l, _cwprintf, _cwprintf_l 的版本与安全增强如 CRT中的安全功能所述。
重要
此 API 不能在运行时的窗口执行的应用程序。有关更多信息,请参见 CRT 函数不支持与 /ZW。
int _cprintf_s(
const char * format [,
argument] ...
);
int _cprintf_s_l(
const char * format,
locale_t locale [,
argument] ...
);
int _cwprintf_s(
const wchar * format [,
argument] ...
);
int _cwprintf_s_l(
const wchar * format,
locale_t locale [,
argument] ...
);
参数
format
窗体控件字符串。argument
可选参数。locale
使用的区域设置。
返回值
打印的字符数。
备注
这些功能设置格式并打印一系列字符和值直接添加到控件中,使用 _putch 功能 ( _cwprintf_s的_putwch ) 到输出字符。 每 argument (如果有) 基于在 format相应的格式规范转换和输出。 该窗体具有窗体和功能和 printf_s 功能的 format 参数相同。 不同 fprintf_s、printf_s和 sprintf_s 功能,_cprintf_s 和 _cwprintf_s 不将换行符转换为支持返回换行符 (CR-LF) 组合,如输出。
重要的区别是 _cwprintf_s 在 Windows NT 显示 Unicode 字符,在使用。 不同 _cprintf_s,_cwprintf_s 使用当前控件个区域设置
这些功能的版本与 _l 后缀的相同,只不过它们使用区域设置参数而不是当前区域设置。
安全说明 |
---|
确保 format 不是用户定义的字符串。 |
与不安全的版本 (参见 _cprintf, _cprintf_l, _cwprintf, _cwprintf_l),这些功能验证其参数并调用无效参数处理程序,如 参数验证所述,因此,如果 format 是一个 null 指针。 这些函数与不安全的版本的不同之处在于格式字符串还验证。 如果有任何未知或有格式的格式化说明符,这些函数调用的参数无效处理程序。 在所有情况下,因此,如果执行允许继续,函数返回 -1 并将 errno 到 EINVAL。
一般文本例程映射
Tchar.h 实例 |
未定义的_UNICODE 和_MBCS |
定义的_MBCS |
定义的_UNICODE |
---|---|---|---|
_tcprintf_s |
_cprintf_s |
_cprintf_s |
_cwprintf_s |
_tcprintf_s_l |
_cprintf_s_l |
_cprintf_s_l |
_cwprintf_s_l |
要求
实例 |
必需的标头 |
---|---|
_cprintf_s,_cprintf_s_l |
<conio.h> |
_cwprintf_s, _cwprintf_s_l |
<conio.h> |
有关更多兼容性信息,请参见中介绍的 兼容性。
库
C 运行库的所有版本。
示例
// crt_cprintf_s.c
// compile with: /c
// This program displays some variables to the console.
#include <conio.h>
int main( void )
{
int i = -16, h = 29;
unsigned u = 62511;
char c = 'A';
char s[] = "Test";
/* Note that console output does not translate \n as
* standard output does. Use \r\n instead.
*/
_cprintf_s( "%d %.4x %u %c %s\r\n", i, h, u, c, s );
}
Output
-16 001d 62511 A Test
请参见
参考
_cscanf, _cscanf_l, _cwscanf, _cwscanf_l
fprintf_s, _fprintf_s_l, fwprintf_s, _fwprintf_s_l
printf_s, _printf_s_l, wprintf_s, _wprintf_s_l
sprintf_s, _sprintf_s_l, swprintf_s, _swprintf_s_l