_snscanf、 _snscanf_l、 _snwscanf、 _snwscanf_l
讀取的格式字串中的指定長度的資料。 這些函式更安全版本都可使用; see _snscanf_s、 _snscanf_s_l、 _snwscanf_s、 _snwscanf_s_l.
int __cdecl _snscanf(
const char * input,
size_t length,
const char * format,
...
);
int __cdecl _snscanf_l(
const char * input,
size_t length,
const char * format,
locale_t locale,
...
);
int __cdecl _snwscanf(
const wchar_t * input,
size_t length,
const wchar_t * format,
...
);
int __cdecl _snwscanf_l(
const wchar_t * input,
size_t length,
const wchar_t * format,
locale_t locale,
...
);
參數
input
若要檢查的輸入的字串。length
要檢查中的字元數input。format
一或多個格式規範。... (optional)
將用來儲存擷取自輸入字串中的格式規範的值的變數format。locale
若要使用地區設定。
傳回值
兩種函式傳回的欄位,順利轉換,並指派; 傳回的值不包括讀取但未指定的欄位。 傳回值 0 表示沒有欄位被指定。 傳回值是EOF的錯誤,或是第一個轉換之前先到達字串的結尾。 如需詳細資訊,請參閱 sscanf。
如果input或format是NULL指標,或者如果length小於或等於為零,無效的參數處理常式會叫用,如所述參數驗證。 如果執行則允許繼續執行,則這些函數會傳回EOF ,並設定errno到EINVAL。
如需這些和其他錯誤碼資訊,請參閱 _doserrno、 errno、 _sys_errlist,以及 _sys_nerr。
備註
這個函式,就像sscanf不同之處在於它可讓您指定固定的數目的字元,來檢查自輸入字串。 如需詳細資訊,請參閱 sscanf。
使用這些函式的版本_l尾碼完全相同,不同之處在於它們使用傳遞中而不是目前執行緒的地區設定的地區設定參數。
泛用文字常式對應
Tchar.h 常式 |
_Unicode 之後,未定義的 _MBCS |
定義的 _MBCS |
定義 _unicode 之後 |
---|---|---|---|
_sntscanf |
_snscanf |
_snscanf |
_snwscanf |
_sntscanf_l |
_snscanf_l |
_snscanf_l |
_snwscanf_l |
需求
常式 |
所需的標頭 |
---|---|
_snscanf, _snscanf_l |
<stdio.h> |
_snwscanf, _snwscanf_l |
<stdio.h> 或者 <wchar.h> |
如需相容性資訊,請參閱相容性在簡介中。
範例
// crt_snscanf.c
// compile with: /W3
#include <stdio.h>
int main( )
{
char str1[] = "15 12 14...";
wchar_t str2[] = L"15 12 14...";
char s1[3];
wchar_t s2[3];
int i;
float fp;
i = _snscanf( str1, 6, "%s %f", s1, &fp); // C4996
// Note: _snscanf is deprecated; consider using _snscanf_s instead
printf("_snscanf converted %d fields: ", i);
printf("%s and %f\n", s1, fp);
i = _snwscanf( str2, 6, L"%s %f", s2, &fp); // C4996
// Note: _snwscanf is deprecated; consider using _snwscanf_s instead
wprintf(L"_snwscanf converted %d fields: ", i);
wprintf(L"%s and %f\n", s2, fp);
}
.NET Framework 對等用法
不適用。 若要呼叫標準的 c 函式,使用PInvoke。 如需詳細資訊,請參閱平台叫用範例。