c标准库总结

c标准库

前言

学习c语言十几年了,却从来没有完整的将c标准库看一看,我想在这一点上我是欠缺的。作为一个技术人员,无论什么时候都不能忘记自己最擅长的技能,这次借一个偶然的契机,翻一翻c标准库,希望以后自己在技术上越来越牛。

说明

c++库和c库包含相同的结构体的定义,其区别主要如下:

  • 每个头文件与c语言版本具有相同的名称,但是带有“c”前缀,没有扩展文件名。例如:c语言头文件<stdio.h>的c++等价头文件为。
  • 库的每个元素都在std空间中定义。

本文档的示例中,使用c风格的版本,要使用c++的版本替换成相应的头文件就好。

在c++版本实现中也有一些特定的区别:

  • wchar_t, char16_t, char32_t 和 bool是c++中的基本类型,因此不会在c版本中出现,这同样适用于<iso646.h>中的宏,因为它们是c++中的关键字。
  • 以下函数的声明中有与其参数常量相关的更改:strchr、strpbrk、strrchr、strstrstr、memchr。
  • 定义在<cstdlib>中的atexit、exit、abort函数在c++中的行为有所增加。
  • 有些函数的重载版本提供了作为参数的附加类型和相同的语义,例如cmath头文件中函数的float和long double版本,或者abs和div的long版本。

c++98包含c90标准中的库;
c++11包含c99标准中描述的c库;
2011 ISO标准的其他介绍与c++不兼容。

说明:本文主要对c99(即c++11)库进行描述。

<cassert>&lt;assert.h>

说明

该文件中定义了一组宏函数作为标准调试工具。对应的宏函数为assert。

函数

函数assert
void assert(int expression);

如果表达式为0,则会向标准错误设备写入一条消息,并调用abort,终止程序的额执行。
如果在#include<assert.h>时,已经定义了名为ndebug的宏,则禁用此宏。因此可以在调试时使用断言,但是在生产版本中通过如下行为禁用这些断言调用:

#define NDEBUG

调用示例:

#include <stdio.h>      /* printf */
#include <assert.h>     /* assert */

void print_number(int* myInt) {
       assert (myInt!=NULL);
       printf ("%d\n",*myInt);
}

int main (){
     int a=10;
     int * b = NULL;
     int * c = NULL;

     b=&a;

     print_number (b);
     print_number (c);

     return 0;
}

<cctype>/<ctype.h>

说明

此头文件声明了一组用于分类和转换单个字符的函数。

函数

isalnum
int isalnum ( int c );

检查c是十进制数字还是大小写字母。如果为假返回0,否则返回其它值。

isalpha
int isalpha ( int c );

检查c是否为字母。为假返回0,否则返回其它值。

isblank
int isblank ( int c );

检查c是否是空白字符。为假返回0,否则返回其它值。

iscntrl
int iscntrl ( int c );

检查c是否是控制字符。为假返回0,否则返回其它值。

isdigit
int isdigit ( int c );

检查c是否是十进制字符。为假返回0,否则返回其它值。

isgraph
int isgraph ( int c );

检查c是否有图形表示法。带有图形表示法的字符是除了空白字符(比如 ’ ')以外的所有可打印的字符。为假返回0,否则返回其它值。

islower
int islower ( int c );

检查c是否是小写字母。为假返回0,否则返回其它值。

isprint
int isprint ( int c );

检查c是否是可打印字符。为假返回0,否则返回其它值。

ispunct
int ispunct ( int c );

检查c是否是标点符号。为假返回0,否则返回其它值。

isspace
int isspace ( int c );

检查c是否是空格。为假返回0,否则返回其它值。

isupper
int isupper ( int c );

检查c是否是大写字母。为假返回0,否则返回其它值。

isxdigit
int isxdigit ( int c );

检查c是否是十六进制数字。为假返回0,否则返回其它值。

tolower
int tolower ( int c );

将c转换成小写字符。

toupper
int toupper ( int c );

将c转换成大写字符。

<cerrno>/<errno.h>

该文件中主要定义了如下宏:

  • errno 上次的错误号;
  • 该宏可以由程序读和写。

<cfloat>/&ltfloat.h>

含了一组与浮点值相关的依赖于平台的常量。

描述
FLT_ROUNDS定义浮点加法的舍入模式,它可以是下列任何一个值: -1 表示无法确定 ; 0 表示趋向于零; 1表示去最近的值; 2趋向于正无穷; 3趋向于负无穷。
FLT_RADIX此宏定义了指数表示的基数。基数2表示二进制,基数10表示十进制,基数16表示十六进制。
FLT_MANT_DIG DBL_MANT_DIG LDBL_MANT_DIG定义了FLT_RADIX基数中的位数
FLT_DIG 6 DBL_DIG 10 LDBL_DIG 10定义了舍入后不会改变表示的十进制数字的最大值。
FLT_MIN_EXP DBL_MIN_EXP LDBL_MIN_EXP定义了基数为FLT_RADIX时的指数的最小负整数值。
FLT_MIN_10_EXP -37 DBL_MIN_10_EXP -37 LDBL_MIN_10_EXP -37定义基数为10时指数的最小负整数值。
FLT_MAX_EXP DBL_MAX_EXP LDBL_MAX_EXP定义基数为FLT_RADIX时指数的最大整数值。
FLT_MAX_10_EXP +37 DBL_MAX_10_EXP +37 LDBL_MAX_10_EXP +37定义基数为10时的指数的最大整数值。
FLT_MAX 1E+37 DBL_MAX 1E+37 LDBL_MAX 1E+37定义最大的有限浮点数。
FLT_EPSILON 1E-5 DBL_EPSILON 1E-9 LDBL_EPSILON 1E-9定义可表示的最小有效数字。
FLT_MIN 1E-37 DBL_MIN 1E-37 LDBL_MIN 1E-37定义最小的浮点数。

<ciso646>/<iso646.h>

定义运算符相关的宏。

对应操作符
and&&
and_eq&=
bitand&
bitor|
compl~
not!
not_eq!=
or||
or_eq|=
xor^
xor_eq^=

在c++中有相应的保留字,因此可以不需要此头文件。

<climits>/<limits.h>

该头文件决定了各种变量类型的各种属性。定义在该头文件中的宏限制各种类型的变量。即变量不能存储任何超出这些限制的值。

描述
CHAR_BITchar类型中的比特数8
SCHAR_MIN有符号字符的最小值-127
SCHAR_MAX有符号字符的最大值127
UCHAR_MAX无符号字符的最大值255
CHAR_MINchar类型的最小值SCHAR_MIN或者0
CHAR_MAXchar类型的最大值SCHAR_MAX或者UCHAR_MAX
MB_LEN_MAX多字节字符中的最大字节数1
SHRT_MIN短整型的最小值-32767(-2^15+1)
SHRT_MAX短整型的最大值32767(2^15+1)
USHRT_MAX无符号短整型的最大值65535(2^16-1)
INT_MINint类型的最小值-32767(-2^15+1)
INT_MAXint类型的最大值32767(2^15+1)
UINT_MAX无符号int类型的最大值65535(2^16-1)
LONG_MIN长整型的最小值-2147483647 (-2^31+1)
LONG_MAX长整型的最大值2147483647 (2^31+1)
ULONG_MAX无符号长整型的最大值4294967295 (2^32-1)
LLONG_MINlong long int的最小值-9223372036854775807 (-2^63+1)
LLONG_MINlong long int的最大值9223372036854775807 (2^63+1)
ULLONG_MAX无符号long long int的最大值18446744073709551615 (2^64-1)

<clocale>/<locale.h>

c语言支持特定于本地化的设置。例如特定于区域性的日期格式或特定于国家的货币符号。
每个系统和特定的编译器至少要提供两种区域设置选择:

  • "c"区域设置是最小区域设置。
  • 系统的默认区域设置由运行应用程序的环境提供区域设置配置。

在此头文件中声明了结构提lconv以及函数setlocale和localeconv,以及配合它们使用的一些宏。

结构体lconv

此结构体保存写入数值(货币值和非货币值)的格式信息。函数localconv返回此类型的对象。
该结构体包含的成员如下:
typedef struct {
char *decimal_point;//用于非货币值的小数点字符
char *thousands_sep;//用于非货币值的千位分隔符
char *grouping;//一个表示非货币量中每组数字大小的字符串。每个字符代表一个整数值,每个整数指定当前组的位数。值为 0 意味着前一个值将应用于剩余的分组
char *int_curr_symbol;//国际货币符号使用的字符串。前三个字符是由 ISO 4217:1987 指定的,第四个字符用于分隔货币符号和货币量
char *currency_symbol;//用于货币的本地符号
char *mon_decimal_point;//用于货币值的小数点字符
char *mon_thousands_sep;//用于货币值的千位分隔符
char *mon_grouping;//一个表示货币值中每组数字大小的字符串。每个字符代表一个整数值,每个整数指定当前组的位数。值为 0 意味着前一个值将应用于剩余的分组
char *positive_sign;//用于正货币值的字符
char *negative_sign;//用于负货币值的字符
char int_frac_digits;//国际货币值中小数点后要显示的位数
char frac_digits;//货币值中小数点后要显示的位数
char p_cs_precedes;//如果等于 1,则 currency_symbol 出现在正货币值之前。如果等于 0,则 currency_symbol 出现在正货币值之后
char p_sep_by_space;//如果等于 1,则 currency_symbol 和正货币值之间使用空格分隔。如果等于 0,则 currency_symbol 和正货币值之间不使用空格分隔
char n_cs_precedes;//如果等于 1,则 currency_symbol 出现在负货币值之前。如果等于 0,则 currency_symbol 出现在负货币值之后
char n_sep_by_space;//如果等于 1,则 currency_symbol 和负货币值之间使用空格分隔。如果等于 0,则 currency_symbol 和负货币值之间不使用空格分隔
char p_sign_posn;//表示正货币值中正号的位置
char n_sign_posn;//表示负货币值中负号的位置
char int_p_cs_precedes;//p_cs_precedes的国际格式
char int_n_cs_precedes;//n_cs_precedes的国际格式
char int_p_sep_by_space;//p_sep_by_space的国际格式
char int_n_sep_by_space;//n_sep_by_space的国际格式
char int_p_sign_posn;//p_sign_posn的国际格式
char int_n_sign_posn;//n_sign_posn的国际格式
} lconv

函数setlocale

char* setlocale (int category, const char* locale);

设置或读取地域化的信息。

函数localeconv

struct lconv* localeconv (void);

设置或读取地域化信息,会返回一个lconv结构类型的对象。

<cmath>/<math.h>

定义了常用的数学操作相关的函数。
如下:

  • cos
  • sin
  • tan
  • acos
  • asin
  • atan
  • atan2
  • cosh
  • sinh
  • tanh
  • acosh
  • asinh
  • atanh
  • exp
  • frexp
  • ldexp
  • log
  • log10
  • modf
  • exp2
  • expm1
  • ilogb
  • log1p
  • log2
  • logb
  • scalbn
  • scalbln
  • pow
  • sqrt
  • cbrt
  • hypot
  • erf
  • erfc
  • tgamma
  • lgamma
  • ceil
  • floor
  • fmod
  • trunc
  • round
  • lround
  • llround
  • rint
  • lrint
  • nearbyint
  • remainder
  • remquo
  • copysign
  • nan
  • nextafter
  • nexttoward
  • fdim
  • fmax
  • fmin
  • fabs
  • abs
  • fma
  • fpclassify
  • isfinite
  • isinf
  • isnan
  • isnormal
  • signbit
  • isgreater
  • isgreaterequal
  • isless
  • islessequal
  • islessgreater
  • isunordered
  • math_errhandling
  • INFINITY
  • NAN
  • HUGE_VAL
  • HUGE_VALF
  • HUGE_VALL

<csetjmp>/<setjmp.h>

定义了宏setjmp、函数longjmp以及变量类型jmp_buf,用来实现远程跳转。

jmp_buf类型

用来存储宏setjmp和longjmp之间的环境相关的信息。在调用setjmp时存储,然后在longjmp时恢复

setjmp

int setjmp (jmp_buf env);

此宏用来把当前的环境保存在变量enviroment中,以便longjmp调用时使用。

longjmp

void longjmp (jmp_buf env, int val);

该函数恢复最近一次调用setjmp宏时保存的环境,就jmp_buf参数的设置是由之前调用的额setjmp生成的。

<csignal>/<signal.h>

处理信号的c标准库。包括sig_atomic_t类型,信号处理设置函数signal,信号生成函数raise。

sig_atomic_t类型

int类型,信号处理程序中作为变量使用。它是一个对象的整数类型,该对象可以作为一个原子实体访问,即使存在异步信号时,该对象可以作为一个原子实体访问。

signal

注册信号处理函数。

raise

生成一个信号。

宏类型

类型信号
int (信号)SIGABRT程序异常终止
int (信号)SIGFPE算术运算出错,如除数为0或者溢出
int (信号)SIGILL非法函数映像,如非法指令
int (信号)SIGINT中断信号,如ctrl-C
int (信号)SIGSEGV非法访问存储器,如访问不存在的内存单元
int (信号)SIGTERM发送给本程序的终止请求信号
函数(handlers)SIG_DFL默认的信号处理程序
函数(handlers)SIG_ERR特殊返回值表示一个信号错误
函数(handlers)SIG_IGN忽略信号

<cstdarg>/<stdarg.h>

该头文件定义了一个变量类型va_list和三个宏,这三个宏可用于在参数个数未知(即参数个数可变)时获取函数中的参数。
可变参数的函数在参数列表的末尾使用省略号(…)定义。
例如:

返回类型 函数名称(参数1, ...)

要访问附加的参数通过宏va_start,va_arg,va_end来实现。

库变量va_list

适用于va_start()、va_arg()和va_end()这三个宏存储信息的类型。

宏库

描述
void va_start (va_list ap, last_arg)此宏初始化ap变量,与va_arg和va_end一起使用。lase_arg是最后一个传递给函数的已知的固定参数,即省略号之前的参数,此参数不应为引用类型。
type va_arg(va_list ap, type)此宏检索函数参数列表中类型为type的下一个参数。
void va_end(va_list ap)此宏允许使用va_start宏带有的可变参数的函数返回。如果在从函数返回之前没有调用va_end,则结果为未定义。
void va_copy (va_list dest, va_list src)拷贝va_list src的内容到dest

<cstdbool>/&ltstdbool.h>

定义true和false的宏。

<cstddef>/<stddef.h>

该头文件定义各种变量类型和宏。

类型

类型含义
ptrdiff_t有符号整数类型,它是两个指针相减的结果
size_t无符号整数类型,它是sizeof关键字的结果
max_align_t对其类型大小
nullptr_t空指针类型

宏函数

类型含义
offset返回结一个构体成员的偏移量

类型含义
NULL空指针

<cstdint>/<stdint.h>

此文件是类型支持库的一部分,提供定宽整数类型和部分c数值极限接口。

类型

int8_t uint8_t
int16_t uint16_t
int32_t uint32_t
int64_t uint64_t
分别为宽度恰为 8 、 16 、 32 和 64 位的有/无符号整数类型
无填充位并对负值使用补码(仅若实现支持该类型才提供)

int_least8_t uint_least8_t
int_least16_t uint_least16_t
int_least32_t uint_least32_t
int_least64_t uint_least64_t
分别为宽度至少有 8 、 16 、 32 和 64 位的最小的有/无符号整数类型

int_fast8_t uint_fast8_t
int_fast16_t uint_fast16_t
int_fast32_t uint_fast32_t
int_fast64_t uint_fast64_t
分别为宽度至少有 8 、 16 、 32 和 64 位的最快的有/无符号整数类型

intmax_t uintmax_t 最大宽度的有/无符号整数类型
intptr_t uintptr_t 足以保有指针的有/无符号整数类型

对应上述类型的最大值、最小值以及特殊值。

<cstdio>/<stdio.h>

输入输出标准库。

流属性

大部分属性在使用fopen打开一个文件的时候定义,如下:

  • 读写权限
  • 文本/二进制
  • 缓冲
  • 流的方向

流标识

主要有以下三种:

  • 错误标识
  • 文件结束标识
  • 位置标识

函数

函数功能
remove删除文件
rename重命名文件
tmpfile打开一个临时文件
tmpnam生成一个临时文件
fclose关闭文件
fflushFlush流
fopen打开文件
freopen把一个新的文件名与给定的打开流相关联,同时关闭流中的旧文件
setbuf设置流的缓冲区
setvbuf定义流缓冲的函数
fprintf格式化写入流
fscanf从流读取格式化输入
printf格式化打印到stdout
scanf从标准输入取
snprintf格式化打印到缓冲中
sprintf发送格式化输出到字符串
sscanf从字符串读取格式化输入
vfprintf使用参数列表发送格式化输出到流中
vfscanf从流中执行格式化输入
vprintf使用参数列表发送格式化输出到标准输出stdout
vscanf字符串格式化输入函数
vsnprintf从参数列表格式化输出到buffer
vsprintf从参数列表格式化输出到字符串
vsscanf从字符串格式输入到参数列表
fgetc从流中取一个字符
fgets从流中取字符串
fputc写入字符到流中
fputs写入字符串到流中
getc从流中取一个字符
getchar从标准输入取一个字符
gets从标准输入取一个字符串
putc写入字符到流中
putchar写字符到标准输出
puts写字符串到标准输出
ungetc把一个字符推入到指定的流中,以便它是下一个被读取到的字符
fread从指定的流中读取数据到所指向的数组中
fwrite写数据到指定的流中
fgetpos获取流中的当前位置
fseek设置流的文件位置给定的偏移
fsetpos设置指定位置
ftell返回给定流的当前文件位置
rewind返回文件位置为给定流的文件的开头
clearerr清除给定流的文件结束和错误标识
feof是否到文件末尾
ferror测试流的错误标识
perror打印错误消息

功能
BUFSIZ缓冲尺寸
EOF文件结束
FILENAME_MAX文件名最大长度
FOPN_MAX能同时打开的文件数量
L_tmpnam字符数组可以存储的由tmpnam函数创建的临时文件名的最大长度
NULL空指针
TMP_MAXtmpnam函数可生成的独特文件名的最大数量

类型

类型描述
FILE适合存储文件流信息的对象类型
fpos_t适合存储文件中任何位置的对象类型
size_t无符号整数类型,是sizeof关键字的结果

<cstdlib>/<stdlib.h>

此文件中定义了一些通用的函数,包括内存动态管理,随机数生成等等。

函数

  • 字符串转换相关:

    函数功能
    atof字符串转换成double类型
    atoi字符串转换成整型
    atol字符串转换成长整型
    atoll字符串转换成长长整型
    strtod字符串转换成double类型
    strtof字符串转换成浮点型
    strtol字符串转换成长整型
    strtold字符串转换成长double型
    strtoll字符串转换成长长整型
    strtoul字符串转换成无符号长整型
    strtoull字符串转换成无符号长长整型
  • 随机相关

    函数功能
    rand生成随机数
    srand初始化随机数生成器
  • 动态内存管理

    函数功能
    calloc分配并且用0初始化数组
    free释放内存
    malloc分配内存
    realloc重新分配内存
  • 环境相关

    函数功能
    abort中止当前进程
    atexit设置执行exit时执行的函数
    at_quick_exit设置执行quick_exit时执行的函数
    exit结束调用进程
    getenv获取环境变量
    quick_exit快速结束调用进程
    system执行系统命令
    _Exit结束调用进程
  • 搜索和排序

    函数功能
    bsearch执行二分查找
    qsort数组排序
  • 整型数相关

    函数功能
    abs求绝对值
    div整数除法
    labs求长整型绝对值
    ldiv求长整型除法
    llabs求长长整型绝对值
    lldiv求长长整型除法
  • 多字节字符

    函数功能
    mblen求多字节字符的长度
    mbtowc将多字节序列转换成宽字符
    wctomb宽字符转换成多字节序列
  • 多字节字符串

    函数功能
    mbstowcs多字节字符串转换成宽字符字符串
    wcstombs宽字符字符串转换成多字节字符串
  • 功能
    EXIT_FAILURE错误结束码
    EXIT_SUCCESS成功结束码
    MB_CUR_MAX多字节字符的最大尺寸
    NULL空指针
    RAND_MAX能随机出来的最大值
  • 类型

    类型功能
    div_tdiv返回的结构体
    ldiv_tldiv返回的结构体
    lldiv_tlldiv返回的结构体
    size_t无符号整型

<cstring>/<string.h>

该头文件中定义了一些函数来维护c语言中的字符串和数组。

函数

  • 拷贝相关

    函数功能
    memcpy拷贝
    memmove用于拷贝字节,如果目标区域和源区域有重叠的话,memmove能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,但复制后源内容会被更改。但是当目标区域与源区域没有重叠则和memcpy函数功能相同。
    strcpy拷贝字符串
    strncpy拷贝字符串
  • 级联相关

    函数功能
    strcat级联
    strncat级联
  • 比较

    函数功能
    memcmp比较两块内存
    strcmp比较两个字符串
    strcoll比较两个字符串,但是结果取决于 LC_COLLATE 的位置设置
    strncmp比较两个字符串中的字符
    strxfrm根据程序当前的
  • 搜索

    函数功能
    memchr搜索前n个字节中第一次出现字符c的位置
    strchr搜索字符串中第一次出现的c的位置
    strcspn检索字符串str1中连续几个字符都不包含字符串str2中的字符
    strpbrk检测str1中地一个匹配字符串str2中字符的字符,不包含空结束字符
    strrchr在参数str只想的字符串中搜索最后一次出现字符c的位置
    strspn检测字符串str1中地一个不在字符串str2中出现的字符下标
    strstr在一个字符串中查找第一次出现另一个字符串的位置
    strtok分解字符串为一组字符串,第二个参数为分割符
  • 其它

    函数功能
    memset给内存块赋值
    strerror获取错误字符串的指针
    strlen获取字符串的长度
  • 功能
    NULL空指针
  • 类型

    类型描述
    size_t无符号整型

<ctgmath>/<tgmath.h>

此头文件简单的包含<cmath>和<ccomplex>

<ctime>/<time.h>

时间相关的库

函数

  • 时间相关

    函数描述
    clock返回程序执行起,处理器时钟所使用的时间
    difftime返回两个time之间相差的秒数
    mktime把tm结构转换成一个依据本地时区的time_t值
    time计算当前日历时间,并把它编码成time_t格式
  • 转换相关

    函数描述
    asctime把tm结构转换成字符串
    ctime把time_v的值转换成字符串
    gmtime把time_t转换成UTC时间的tm
    localtime把time_t转换成本地时间的tm
    strftime格式化时间为字符串
  • 描述
    CLOCKS_PER_SEC时钟每秒的滴答数
    NULL空指针
  • 类型

    描述
    clock_t时钟类型
    size_t无符号整型
    time_t时间类型
    struct time时间结构体

<cuchar>/<uchar.h>

此头文件用来支持UTF-16和UTF-32.

描述
STD_UTF_16如果定义了此值则说明char16_t有UTF-16编码
STD_UTF_32如果定义了此值则说明char32_t有UTF-32编码

函数

函数描述
c16rtomb将16位字符转换成多字节序列
c32rtomb将32位字符转换成多字节序列
mbrtoc16将多字节序列转换成16位字符
mbrtoc32将多字节序列转换成32位字符

<cwchar>/<wchar.h>

此文件主要描述宽字符串相关的内容。

函数

  • 输入/输出

    函数功能
    fgetwc从流中读取宽字符
    fgetws从流中读取宽字符串
    fputwc写宽字符到流中
    fputws写宽字符串到流中
    fwide检测流方向
    fwprintf写格式化数据到流
    fwscanf从流中读格式化数据
    getwc从流中获取宽字符
    getwchar从标准输入获取宽字符
    putwc给流写宽字符
    putwchar给标准输出写宽字符
    swprintf写格式化数据到宽字符串
    swscanf从流中读格式化数据
    ungetwc回退一个wc到流中
    vfwprintf从参数列表输出到流中
    vfwscanf从流中读入到参数列表
    vswprintf同上
    vswscanf同上
    vwprintf同上
    vwscanf同上
    wprinf同上
    wscanf同上
  • 常规

    wcstod
    wcstof
    wcstol
    wcstold
    wcstoll
    wcstoul
    wcstoull

  • 字符和字符串转换

    btowc
    mbrlen
    mbrtowc
    mbsinit
    mbsrtowcs
    wcrtomb
    wctob
    wcsrtombs

  • 字符串

    wcscat
    wcschr
    wcscmp
    wcscoll
    wcscpy
    wcscspn
    wcslen
    wcsncat
    wcsncmp
    wcsncpy
    wcspbrk
    wcsrchr
    wcsspn
    wcsstr
    wcstok
    wcsxfrm
    wmemchr
    wmemcmp
    wmemcpy
    wmemmove
    wmemset

  • 时间

    wcsftime

  • 类型

    mbstate_t
    size_t
    struct tm
    wchar_t
    wint_t

  • NULL
    WCAHR_MAX
    WCHAR_MIN
    WEOF

<cwctype>/wctype.h>

宽字符类型相关。

函数

iswalnum
iswalpha
iswblank
iswcntrl
iswdigit
iswgraph
iswlower
iswprint
iswpunct
iswspace
iswupper
iswxdigit

towlower
towupper

iswctype
towctrans
wctrans
wctype

类型

wctrans_t
wctype_t
wint_t

其它

WEOF

  • 22
    点赞
  • 114
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值