命名空间
变体
操作

wctob

来自 cppreference.cn
< c‎ | string‎ | multibyte
定义于头文件 <wchar.h>
int wctob( wint_t c );
(since C95)

如果宽字符 c 在初始移位状态下的多字节字符等效字符是单字节,则将其窄化。

这对于来自 ASCII 字符集的字符通常是可能的,因为大多数多字节编码(如 UTF-8)使用单字节来编码这些字符。

目录

[编辑] 参数

c - 要窄化的宽字符

[编辑] 返回值

EOF 如果 c 不表示初始移位状态下长度为 1 的多字节字符。

否则,c 的单字节表示形式为 unsigned char 并转换为 int

[编辑] 示例

#include <locale.h>
#include <wchar.h>
#include <stdio.h>
#include <assert.h>
 
void try_narrowing(wchar_t c)
{
    int cn = wctob(c);
    if(cn != EOF)
        printf("%#x narrowed to %#x\n", c, cn);
    else
        printf("%#x could not be narrowed\n", c);
}
 
int main(void)
{
    char* utf_locale_present = setlocale(LC_ALL, "th_TH.utf8");
    assert(utf_locale_present);
    puts("In Thai UTF-8 locale:");
    try_narrowing(L'a');
    try_narrowing(L'๛');
 
    char* tis_locale_present = setlocale(LC_ALL, "th_TH.tis620");
    assert(tis_locale_present);
    puts("In Thai TIS-620 locale:");
    try_narrowing(L'a');
    try_narrowing(L'๛');
}

可能的输出

In Thai UTF-8 locale:
0x61 narrowed to 0x61
0xe5b could not be narrowed
In Thai TIS-620 locale:
0x61 narrowed to 0x61
0xe5b narrowed to 0xfb

[编辑] 参考

  • C11 标准 (ISO/IEC 9899:2011)
  • 7.29.6.1.2 wctob 函数 (p: 441)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.24.6.1.2 wctob 函数 (p: 387)

[编辑] 参见

(C95)
如果可能,将单字节窄字符扩展为宽字符
(函数) [编辑]
C++ 文档 for wctob