宽字符处理函数函数与普通函数对照表
字符分类: 宽字符函数普通C函数描述
iswalnum() isalnum() 测试字符是否为数字或字母
iswalpha() isalpha() 测试字符是否是字母
iswcntrl() iscntrl() 测试字符是否是控制符
iswdigit() isdigit() 测试字符是否为数字
iswgraph() isgraph() 测试字符是否是可见字符
iswlower() islower() 测试字符是否是小写字符
iswprint() isprint() 测试字符是否是可打印字符
iswpunct() ispunct() 测试字符是否是标点符号
iswspace() isspace() 测试字符是否是空白符号
iswupper() isupper() 测试字符是否是大写字符
iswxdigit() isxdigit()测试字符是否是十六进制的数字

大小写转换:
宽字符函数普通C函数描述
towlower() tolower() 把字符转换为小写
towupper() toupper() 把字符转换为大写

字符比较: 宽字符函数普通C函数描述
wcscoll() strcoll() 比较字符串

日期和时间转换:
宽字符函数描述
strftime() 根据指定的字符串格式和locale设置格式化日期和时间
wcsftime() 根据指定的字符串格式和locale设置格式化日期和时间, 并返回宽字符串
strptime() 根据指定格式把字符串转换为时间值, strftime的反过程

打印和扫描字符串:
宽字符函数描述
fprintf()/fwprintf() 使用vararg参量的格式化输出
fscanf()/fwscanf() 格式化读入
printf() 使用vararg参量的格式化输出到标准输出
scanf() 从标准输入的格式化读入
sprintf()/swprintf() 根据vararg参量表格式化成字符串
sscanf() 以字符串作格式化读入
vfprintf()/vfwprintf() 使用stdarg参量表格式化输出到文件
vprintf() 使用stdarg参量表格式化输出到标准输出
vsprintf()/vswprintf() 格式化stdarg参量表并写到字符串

数字转换:
宽字符函数普通C函数描述
html符号代码对照表wcstod() strtod() 把宽字符的初始部分转换为双精度浮点数
wcstol() strtol() 把宽字符的初始部分转换为长整数
wcstoul() strtoul() 把宽字符的初始部分转换为无符号长整数

多字节字符和宽字符转换及操作:
宽字符函数描述
mblen() 根据locale的设置确定字符的字节数
mbstowcs() 把多字节字符串转换为宽字符串
mbtowc()/btowc()把多字节字符转换为宽字符
wcstombs() 把宽字符串转换为多字节字符串
wctomb()/wctob() 把宽字符转换为多字节字符

输入和输出:
宽字符函数普通C函数描述
fgetwc() fgetc() 从流中读入一个字符并转换为宽字符
fgetws() fgets() 从流中读入一个字符串并转换为宽字符串
fputwc() fputc() 把宽字符转换为多字节字符并且输出到标准输出
fputws() fputs() 把宽字符串转换为多字节字符并且输出到标准输出串
getwc() getc() 从标准输入中读取字符, 并且转换为宽字符
getwchar() getchar() 从标准输入中读取字符, 并且转换为宽字符
None gets() 使用fgetws()
putwc() putc() 把宽字符转换成多字节字符并且写到标准输出
putwchar() putchar() 把宽字符转换成多字节字符并且写到标准输出
None puts() 使用fputws()
ungetwc() ungetc() 把一个宽字符放回到输入流中

字符串操作:
宽字符函数普通C函数描述
wcscat() strcat() 把一个字符串接到另一个字符串的尾部
wcsncat() strncat() 类似于wcscat(), 而且指定粘接字符串的粘接长度.
wcschr() strchr() 查子字符串的第一个位置
wcsrchr() strrchr() 从尾部开始查子字符串出现的第一个位置
wcspbrk() strpbrk() 从一字符字符串中查另一字符串中任何一个字符第一次出现的位置
wcswcs()/wcsstr() strchr() 在一字符串中查另一字符串第一次出现的位置
wcscspn() strcspn() 返回不包含第二个字符串的的初始数目
wcsspn() strspn() 返回包含第二个字符串的初始数目
wcscpy() strcpy() 拷贝字符串
wcsncpy() strncpy() 类似于wcscpy(), 同时指定拷贝的数目
wcscmp() strcmp() 比较两个宽字符串
wcsncmp() strncmp() 类似于wcscmp(), 还要指定比较字符字符串的数目
wcslen() strlen() 获得宽字符串的数目
wcstok() strtok() 根据标示符把宽字符串分解成一系列字符串
wcswidth() None 获得宽字符串的宽度
wcwidth() None 获得宽字符的宽度


另外还有对应于memory操作的 wmemcpy(), wmemchr(), wmemcmp(), wmemmove(), wmemset().

操作                      ANSI串函数                                Unicode串函数
Length                strlen                                          wcslen
Concatenate        strcat, strncat                            wcscat, wcsncat, RtlAppendUnicodeStringToString, RtlAppendUnicodeToString
Copy                    strcpy, strncpy, RtlCopyString    wcscpy, wcsncpy, RtlCopyUnicodeString
Reverse              _strrev                                        _wcsrev
Compare              strcmp, strncmp, _stricmp, _strnicmp, RtlCompareString, RtlEqualString          wcscmp, wcsncmp, _wcsicmp, _wcsnicmp, RtlCompareUnicodeString, RtlEqualUnicodeString, RtlPrefixUnicodeString
Initialize              _strset, _strnset, RtlInitAnsiString, RtlInitString        _wcsnset, RtlInitUnic
odeString
Search                strchr, strrchr, strspn, strstr          wcschr, wcsrchr, wcsspn, wcsstr
Upper/lowercase _strlwr, _strupr, RtlUpperString      _wcslwr, _wcsupr, RtlUpcaseUnicodeString
Character            isdigit, islower, isprint, isspace, isupper, isxdigit, tolower, toupper, RtlUpperChar          towlower, towupper, RtlUpcaseUnicodeChar
Format                sprintf, vsprintf, _snprintf, _vsnprintf,_splitpath                swprintf, _snwprintf,_wsplitpath
String conversion    atoi, atol, _itoa _itow, RtlIntegerToUnicodeString, RtlUnicodeStringToInteger
Type conversion      RtlAnsiStringToUnicodeSize, RtlAnsiStringToUnicodeString RtlUnicodeStringToAnsiString
Memory release        RtlFreeAnsiString        RtlFreeUnicodeString
C函数来UnicodeANSI文字

char sChar[MAX_PATH];
const WCHAR wChar[] = L"我的朋友";
// wChar这个Unicode字符串换成ANSI字符串,保存到sChar,并且返回ANSI的字符串大小,如果失败,则返回-1
wcstombs(sChar, wChar, MAX_PATH);

这样是运行不过不去的,总是返回-1

后来经人提醒,需要在调用wcstombs之前要先设置代码页:

char sChar[MAX_PATH];
const WCHAR wChar[] = L"我的朋友";

// 设置代码页为默认代码页
_tsetlocale(LC_ALL,_T(""));
/
/ wChar这个Unicode字符串换成ANSI字符串,保存到sChar,并且返回ANSI的字符串大小,如果失败,则返回-1
wcstombs(sChar, wChar, MAX_PATH);


这样就可以了!不用调用烦人的WideCharToMultiByte!多好啊!
相反的函数:mbstowcs,可以从ANSI换到Unicode

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。