_cprintf_s、_cprintf_s_l、_cwprintf_s、_cwprintf_s_l
更新 : 2007 年 11 月
書式化してコンソールに出力します。これらの関数は、「CRT のセキュリティ強化」に説明されているように、_cprintf、_cprintf_l、_cwprintf、_cwprintf_l のセキュリティが強化されたバージョンです。
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: carriage return–line feed) の組み合わせに変換しません。
_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 ランタイム ライブラリ」の「互換性」を参照してください。
ライブラリ
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 );
}
出力
-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