<wctype.h>
-- 函数
阅读:0
作者:严长生
iswprint() 判断一个宽字符是否是可打印字符
int iswprint (wint_t wc);
iswprint() 函数用来检测一个宽字符是否是可打印字符。“可打印字符”是指那些会显示在屏幕上、会占用字符位置的“普通”字符。
可打印字符和控制字符是相对的,控制字符是指那些具有某种特殊功能、不会显示在屏幕上、不会占用字符位置的“特殊”字符。要检测一个宽字符是否是控制字符,请使用 iswcntrl() 函数。
在默认的区域设置(设置为
"C"
)中,C语言使用的是 ASCII 编码,可打印字符的 ASCII 码的范围是0x20(' ') ~ 0x7e('~')
,也就是除了 ASCII 编码最后一个字符0x7f (DEL)
以外,0x20
后面的所有字符都是可打印字符。iswprint() 是 isprint()(位于<ctype.h>中)的宽字符版本:如果参数 wc 能够被 wctob() 转换为单个字节的形式,并且转换后的字符使用 isprint() 检测返回“真”(非零值),那么 iswprint() 也一定会将 wc 判定为可打印字符。
参数
-
wc
要检测的宽字符。它可以是一个有效的宽字符(被转换为 wint_t 类型),也可以是 WEOF(表示无效的宽字符)。
返回值
返回值为非零(真)表示wc
是可打印字符,返回值为零(假)表示wc
不是可打印字符。
实例
输出一个宽字符串中的所有可打印字符。#include <stdio.h> #include <wchar.h> #include <wctype.h> int main () { int i=0; wchar_t str[]=L"first line \n second line \n third line"; while(str[i]) { if(iswprint(str[i])) putwchar (str[i]); i++; } return 0; }运行结果:
first line second line third line
这段代码使用 while 循环来遍历 str 中的所有字符,如果当前的宽字符是可打印字符,那么输出,否则就不输出。对于 str,除
\n
和\0
以外都是可打印字符。
关于可打印字符
一个宽字符是否是可打印字符和程序的语言环境有关。C语言支持全球的语言系统,可以处理英文、中文、日文、韩文、德语、法语、拉丁文、希腊文等。我们可以通过 setlocale() 函数进行地域设置,改变程序的语言环境,让程序使用 ASCII 以外的字符集,它们可能包含了更多的控制字符。
在默认的地域设置(默认为
"C"
)中,C语言通常使用 ASCII 编码,能较好地支持英文,此时的可打印字符就是从0x20(' ') ~ 0x7e('~')
之间的字符,也就是除了最后一个字符0x7f (DEL)
外,0x20
以后的所有字符都是可打印字符。在其它地域设置中,程序可能会使用 GBK(简体中文)、BIG5(繁体中文)、Shift-JIS(日文)、Unicode(世界统一码) 等更加复杂的编码,它们包含了大量的可打印字符。以中文环境为例,汉字
函数手册
、标点,。、!
、罗马数字ⅢⅥⅦXII
都将成为可打印字符。【实例】在简体中文环境下检测可打印字符。
#include <wchar.h> #include <wctype.h> #include <locale.h> int main () { int i=0; wchar_t str[]=L"C语言函数手册 \n http://data.biancheng.net \n 学习C语言的好帮手"; setlocale(LC_ALL, "zh_CN.UTF-8"); //设置为简体中文,使用 UTF-8 编码 //在 Windows 下可以写作 setlocale(LC_ALL, ""); 或者 setlocale(LC_ALL, "chs"); //在 Linux 下可以写作 setlocale(LC_ALL, ""); 或者 setlocale(LC_ALL, "zh_CN.UTF-8"); //在 Mac OS 下可以写作 setlocale(LC_ALL, "zh_CN"); 或者 setlocale(LC_ALL, "zh_CN.UTF-8"); while(str[i]) { if(iswprint(str[i])) putwchar (str[i]); i++; } return 0; }运行结果:
C语言函数手册 http://data.biancheng.net 学习C语言的好帮手
\n
是控制字符,不是可打印字符,不会输出,所以输出结果中没有换行效果。