_cprintf_p、_cprintf_p_l、_cwprintf_p、_cwprintf_p_l
更新 : 2007 年 11 月
書式指定文字列で位置指定パラメータをサポートし、書式化してコンソールに出力します。
int _cprintf_p(
const char * format [,
argument] ...
);
int _cprintf_p_l(
const char * format,
locale_t locale [,
argument] ...
);
int _cwprintf_p(
const wchar * format [,
argument] ...
);
int _cwprintf_p_l(
const wchar * format,
locale_t locale [,
argument] ...
);
パラメータ
format
書式指定文字列。argument
省略可能なパラメータ。locale
使用するロケール。
戻り値
出力した文字数。エラーが発生した場合は負の値を返します。
解説
これらの関数は、文字を出力する _putch 関数と _putwch 関数を使用し、一連の文字や値を書式化して直接コンソールに出力します。各 argument (指定されている場合) は、format 中の対応する書式指定に応じて変換され、格納されます。書式には、printf_p 関数の format パラメータと同じ形式と関数があります。_cprintf_p と cprintf_s の違いは、_cprintf_p では位置指定パラメータをサポートし、これによって、書式指定文字列で引数を使用する順序を指定できることです。詳細については、「printf_p の位置指定パラメータ」を参照してください。
fprintf_p、printf_p、sprintf_p の各関数とは異なり、_cprintf_p も _cwprintf_p も、出力時にライン フィード文字をキャリッジ リターンとライン フィード (CR-LF: carriage return–line feed) の組み合わせに変換しません。_cwprintf_p を Windows NT で使用すると、Unicode 文字が表示される点に注意してください。_cprintf_p と異なり、_cwprintf_p はコンソールの現在のロケール設定を使用します。
_l サフィックスが付いているこれらの関数の各バージョンは、現在のロケールの代わりに渡されたロケール パラメータを使用する点を除いて同じです。
セキュリティに関するメモ : |
---|
format にユーザー定義の文字列を指定しないでください。 |
また、_cprintf_s 関数や _cwprintf_s 関数と同様に、これらの関数は入力ポインタを検証して文字列を書式化します。format または argument が NULL の場合、あるいは書式指定文字列に無効な書式指定文字が含まれている場合、これらの関数は「パラメータの検証」に説明されているように、無効なパラメータ ハンドラを呼び出します。実行の継続が許可された場合、これらの関数は -1 を返し、errno を EINVAL に設定します。
汎用テキスト ルーチンのマップ
Tchar.h のルーチン |
_UNICODE および _MBCS が未定義の場合 |
_MBCS が定義されている場合 |
_UNICODE が定義されている場合 |
---|---|---|---|
_tcprintf_p |
_cprintf_p |
_cprintf_p |
_cwprintf_p |
_tcprintf_p_l |
_cprintf_p_l |
_cprintf_p_l |
_cwprintf_p_l |
必要条件
ルーチン |
必須ヘッダー |
---|---|
_cprintf_p, _cprintf_p_l |
<conio.h> |
_cwprintf_p, _cwprintf_p_l |
<conio.h> |
互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。
使用例
// crt_cprintf_p.c
// This program displays some variables to the console
// using the _cprintf_p function.
#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_p( "%2$d %1$.4x %3$u %4$c %5$s\r\n",
h, i, u, c, s );
}
-16 001d 62511 A Test
参照
参照
_cscanf、_cscanf_l、_cwscanf、_cwscanf_l
_cscanf_s、_cscanf_s_l、_cwscanf_s、_cwscanf_s_l
_fprintf_p、_fprintf_p_l、_fwprintf_p、_fwprintf_p_l
fprintf、_fprintf_l、fwprintf、_fwprintf_l
_printf_p、_printf_p_l、_wprintf_p、_wprintf_p_l
printf、_printf_l、wprintf、_wprintf_l
_sprintf_p、_sprintf_p_l、_swprintf_p、_swprintf_p_l
_vfprintf_p、_vfprintf_p_l、_vfwprintf_p、_vfwprintf_p_l
_cprintf_s、_cprintf_s_l、_cwprintf_s、_cwprintf_s_l