int iswgraph (wint_t wc);
iswgraph() 函数用来检测一个宽字符是否是图形字符。
在可打印字符(iswprint() 返回“真”)中,绝大部分字符既会占用一个字符位置,又会在屏幕上显示出来,这些字符就是图形字符。但是有个别的字符只占用位置却不显示,在 ASCII 编码中,这样的字符只有一个,就是空格(' ')。
对于计算机来说,我们在显示器上看到的所有元素(包括图片、文字、背景、动画等)其实都是图形,计算机都需要把它们绘制出来,只不过文字和图片在操作上有很大的不同,我们在使用时一般不会将文字作为图形对待。
我们说一个字符是图形字符,就是说这个字符需要在显示器上绘制出来,而空格、换行、Tab缩进等字符只会占用输出的位置,不需要绘制。
iswcntrl()、iswspace()、iswblank() 的字符肯定不是 iswgraph() 的字符,iswupper()、iswlower()、iswalpha()、iswdigit()、iswalnum() 的字符肯定是 iswgraph() 的字符,iswgraph() 的字符肯定是 iswprint() 的字符。
iswgraph() 是 isgraph()(位于<ctype.h>中)的宽字符版本:如果参数 wc 能够被 wctob() 转换为单个字节的形式,并且转换后的字符使用 isgraph() 检测返回“真”(非零值),那么 iswgraph() 也一定会将 wc 判定为图形字符。
返回值为非零(真)表示wc是图形字符,返回值为零(假)表示wc不是图形字符。
统计一个宽字符串中图形字符的个数。
#include <stdio.h>
#include <wchar.h>
#include <wctype.h>
int main ()
{
int i=0;
int cx=0;
wchar_t str[] = L"C C++ Java";
while (str[i])
{
if (iswgraph(str[i])) cx++;
i++;
}
wprintf (L"There are %d wide characters have graphical representation.\n", cx);
return 0;
}
运行结果:
一个宽字符是否是图形字符和程序的语言环境有关。C语言支持全球的语言系统,可以处理英文、中文、日文、韩文、德语、法语、拉丁文、希腊文等。
我们可以通过 setlocale() 函数进行地域设置,改变程序的语言环境,让程序使用 ASCII 以外的字符集,它们可能包含了更多的图形字符。
在默认的地域设置(默认为"C")中,C语言通常使用 ASCII 编码,能较好地支持英文,此时的图形字符就是从0x21(' ') ~ 0x7e('~')之间的字符,也就是除了最后一个字符0x7f (DEL)外,0x21以后的所有字符都是图形字符。
在其它地域设置中,程序可能会使用 GBK(简体中文)、BIG5(繁体中文)、Shift-JIS(日文)、Unicode(世界统一码) 等更加复杂的编码,它们包含了大量的图形字符。以中文环境为例,汉字函数手册、标点,。、!、罗马数字ⅢⅥⅦXII都将成为图形字符。
【实例】在简体中文环境下检测图形字符。
#include <stdio.h>
#include <wchar.h>
#include <wctype.h>
#include <locale.h>
int main ()
{
int i=0;
int cx=0;
wchar_t str[] = L"编程语言:C语言 C++ Java";
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 (iswgraph(str[i])) cx++;
i++;
}
wprintf (L"There are %d wide characters have graphical representation.\n", cx);
return 0;
}
运行结果: