- 写在前面
C++是一门博大精深的语言,也是最难学的一门编程语言,每一位励志学好C++的程序员都需要从基本功开始,稳扎稳打.
自从1998年C++ standard定案以后,C++程序库便有了大幅扩充.然而以下这些库函数可谓是C++其他库函数的根.
标准头文件包括:
<asset.h> <ctype.h> <errno.h> <float.h>
<limits.h> <locale.h> <math.h> <setjmp.h>
<signal.h> <stdarg.h> <stddef.h> <stdlib.h>
<stdio.h> <string.h> <time.h>
标准定义(<stddef.h>)
文件<stddef.h>里包含了标准库的一些常用定义,无论我们包含哪个标准头文件,<stddef.h>都会被自动包含进来。这个文件里定义:
类型size_t(sizeof运算符的结果类型,是某个无符号整型);
类型ptrdiff_t(两个指针相减运算的结果类型,是某个有符号整型);
类型wchar_t(宽字符类型,是一个整型,其中足以存放本系统所支持的所有本地环境中的字符
集的所有编码值。这里还保证空字符的编码值为0);
符号常量NULL(空指针值);
宏offsetor(这是一个带参数的宏,第一个参数应是一个结构类型,第二个参数应是结构成员名。offsetor(s,m)求出成员m在结构类型t的变量里的偏移量)。
其中有些定义也出现在其他头文件里(如NULL)。
错误信息(<errno.h>)
<errno.h>定义了一个int类型的表达式errno,可以看作一个变量,其初始值为0,一些标准库函数执行中出错时将它设为非0值,但任何标准库函数都设置它为0。
<errno.h>里还定义了两个宏EDOM和ERANGE,都是非0的整数值。数学函数执行中遇到参数错误,就会将errno置为EDOM,如出现值域错误就会将errno置为ERANGE。
几个最常用头文件
输入输出函数(<stdio.h>)
文件打开和关闭:
FILE *fopen(const char *filename, const char *mode);
int fclose(FILE * stream);
字符输入输出:
int fgetc(FILE *fp);
int fputc(int c, FILE *fp);
getc和putc与这两个函数类似,但通过宏定义实现。通常有下面定义:
#define getchar() getc(stdin)
#define putchar(c) putc(c, stdout)
int ungetc(int c, FILE* stream); 把字符 c 退回流 stream
格式化输入输出:
int scanf(const char *format, ...);
int printf(const char *format, ...);
int fscanf(FILE *stream, const char *format, ...);
int fprintf(FILE *stream, const char *format, ...);
int sscanf(char *s, const char *format, ...);
int sprintf(char *s, const char *format, ...);
行式输入输出:
char *fgets(char *buffer, int n, FILE *stream);
int fputs(const char *buffer, FILE *stream);
char *gets(char *s);
int puts(const char *s);
直接输入输出:
size_t fread(void *pointer, size_t size,
size_t num, FILE *stream);
size_t fwrite(const void *pointer, size_t size,
size_t num, FILE *stream);
数学函数(<math.h>)
三角函数:
三角函数 |
sin |
cos |
tan |
反三角函数 |
asin |
acos |
atan |
双曲函数 |
sinh |
cosh |
tanh |
指数和对数函数:
以e为底的指数函数 |
exp |
自然对数函数 |
log |
以10为底的对数函数 |
log10 |
其他函数:
平方根 |
sqrt |
绝对值 |
fabs |
乘幂,第一个参数作为底,第二个是指数 |
double pow(double, double) |
实数的余数,两个参数分别是被除数和除数 |
double fmod(double, double) |
所有上面未给出类型特征的函数都取一个参数,其参数与返回值都是double类型。
下面函数返回双精度值(包括函数ceil和floor)。在下表里,除其中有特别说明的参数之外,所有函数的其他参数都是double类型。
函数原型 |
意义解释 |
ceil(x) |
求出不小于x的最小整数(返回与这个整数对应的double值) |
floor(x) |
求出不大于x的最大整数(返回与这个整数对应的double值) |
atan2(y, x) |
求出tan-1(y/x),其值的范围是[- 派, 派] |
ldexp(x, int n) |
求出x*( 2n) |
frexp(x, int *exp) |
把 x分解为y*( 2n),y是位于区间[1/2,1]里的一个小数,作为函数结果返回,整数 n通过指针*exp返回(应提供一个int变量地址)。当 x为0时这两个结果的值都是0 |
modf(x, double *ip) |
把x分解为小数部分和整数部分,小数部分作为函数返回值,整数部分通过指针*ip返回。 |
字符处理函数(<ctype.h>),见下表:
int isalpha(c) |
c是字母字符 |
int isdigit(c) |
c是数字字符 |
int isalnum(c) |
c是字母或数字字符 |
int isspace(c) |
c是空格、制表符、换行符 |
int isupper(c) |
c是大写字母 |
int islower(c) |
c是小写字母 |
int iscntrl(c) |
c是控制字符 |
int isprint(c) |
c是可打印字符,包括空格 |
int isgraph(c) |
c是可打印字符,不包括空格 |
int isxdigit(c) |
c是十六进制数字字符 |
int ispunct(c) |
c是标点符号 |
int tolower(int c) |
当c是大写字母时返回对应小写字母,否则返回c本身 |
int toupper(int c) |
当c是小写字母时返回对应大写字母,否则返回c本身 |
条件成立时这些函数返回非0值。最后两个转换函数对于非字母参数返回原字符。
字符串函数(<string.h>)
字符串函数
所有字符串函数列在下表里,函数描述采用如下约定:s、t表示 (char *)类型的参数,cs、ct表示(const char*)类型的参数(它们都应表示字符串)。n表示size_t类型的参数(size_t是一个无符号的整数类型),c是整型参数(在函数里转换到 char):
函数原型 |
意义解释 |
size_t strlen(cs) |
求出cs的长度(不包含‘ |