类型size_t(sizeof运算符的结果类型,是某个无符号整型);
类型ptrdiff_t(两个指针相减运算的结果类型,是某个有符号整型);
类型wchar_t(宽字符类型,是一个整型,其中足以存放本系统所支持的所有本地环境中的字符集的所有编码值。这里还保证空字符的编码值为0);
符号常量NULL(空指针值);
宏offsetot (这是一个带参数的宏,第一个参数应是一个结构类型,第二个参数应是结构成员名。
offsetot(s,m)
FILE *fopen(const char *filename, const char *mode);
int fclose(FILE * stream);
int fgetc(FILE *fp);
int fputc(int c, FILE *fp);
#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);
三角函数 | sin | cos | tan |
反三角函数 | asin | acos | atan |
双曲函数 | sinh | cosh | tanh |
2、指数和对数函数
以e为底的指数函数 | exp |
自然对数函数 | log |
以10为底的对数函数 | log10 |
3.其他函数
平方根 | sqrt |
绝对值 | fabs |
乘幂,第一个参数作为底,第二个是指数 | double pow(double, double) |
实数的余数,两个参数分别是被除数和除数 | double fmod(double, double) |
函数原型 | 意义解释 |
ceil(x) | 求出不小于x的最小整数(返回与这个整数对应的double值) |
floor(x) | 求出不大于x的最大整数(返回与这个整数对应的double值) |
atan2(y, x) | 求出 tan-1(y/x),其值的范围是[-pai,pai] |
ldexp(x, int n) | 求出x*2n |
frexp(x, int *exp) | 把 x分解为 y*2n, 是位于区间 [1/2,1)里的一个小数,作为函数结果返回,整数n 通过指针*exp返回(应提供一个int变量地址)。当x 为0时这两个结果的值都是0 |
modf(x, double *ip) | 把x分解为小数部分和整数部分,小数部分作为函数返回值,整数部分通过指针*ip返回。 |
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本身 |
函数原型 | 意义解释 |
size_t strlen(cs) | 求出cs的长度 |
char *strcpy(s,ct) | 把ct复制到s。要求s指定足够大的字符数组 |
char *strncpy(s,ct,n) | 把ct里的至多n个字符复制到s。要求s指定一个足够大的字符数组。如果ct里的字符不够n个,就在s里填充空字符。 |
char *strcat(s,ct) | 把ct里的字符复制到s里已有的字符串之后。s应指定一个保存着字符串,而且足够大的字符数组。 |
char *strncat(s,ct,n) | 把ct里的至多n个字符复制到s里已有的字符串之后。s应指定一个保存着字符串,而且足够大的字符数组。 |
int strcmp(cs,ct) | 比较字符串cs和ct的大小,在cs大于、等于、小于ct时分别返回正值、0、负值。 |
int strncmp(cs,ct,n) | 比较字符串cs和ct的大小,至多比较n个字符。在cs大于、等于、小于ct时分别返回正值、0、负值。 |
char *strchr(cs,c) | 在cs中查寻c并返回c第一个出现的位置,用指向这个位置的指针表示。当cs里没有c时返回值NULL |
char *strrchr(cs,c) | 在cs中查寻c并返回c最后一个出现的位置,没有时返回NULL |
size_t strspn(cs,ct) | 由cs起确定一段全由ct里的字符组成的序列,返回其长度 |
size_t strcspn(cs,ct) | 由cs起确定一段全由非ct里的字符组成的序列,返回其长度 |
char *strpbrk(cs,ct) | 在cs里查寻ct里的字符,返回第一个满足条件的字符出现的位置,没有时返回NULL |
char *strstr(cs,ct) | 在cs中查寻串ct(查询子串),返回ct作为cs的子串的第一个出现的位置,ct未出现在cs里时返回NULL |
char *strerror(n) | 返回与错误编号n相关的错误信息串(指向该错误信息串的指针) |
char *strtok(s,ct) | 在s中查寻由ct中的字符作为分隔符而形成的单词 |
函数原型 | 意义解释 |
void *memcpy(s,ct,n) | 从ct处复制n个字符到s处,返回s |
void *memmove(s,ct,n) | 从ct处复制n个字符到s处,返回s,这里的两个段允许重叠 |
int memcmp(cs,ct,n) | 比较由cs和ct开始的n个字符,返回值定义同strcmp |
void *memchr(cs,c,n) | 在n个字符的范围内查寻c在cs中的第一次出现,如果找到,返回该位置的指针值,否则返回NULL |
void *memset(s,c,n) | 将s的前n个字符设置为c,返回s |
函数原型 | 意义解释 |
int rand(void) | 生成一个0到RAND_MAX的随机整数 |
void srand(unsigned seed) | 用seed为随后的随机数生成设置种子值 |
2、动态存储分配函数
函数原型 | 意义解释 |
void *calloc(size_t n, size_t size) | 分配一块存储,其中足以存放n个大小为size的对象,并将所有字节用0字符填充。返回该存储块的地址。不能满足时返回NULL |
void *malloc(size_t size) | 分配一块足以存放大小为size的存储,返回该存储块的地址,不能满足时返回NULL |
void *realloc(void *p, size_t size) | 将p所指存储块调整为大小size,返回新块的地址。如能满足要求,新块的内容与原块一致;不能满足要求时返回NULL,此时原块不变 |
void free(void *p) | 释放以前分配的动态存储块 |
函数原型 | 意义解释 |
int abs(int n) | 求整数的绝对值 |
long labs(long n) | 求长整数的绝对值 |
div_t div(int n, int m) | 求n/m,商和余数分别存放到结果结构的对应成员里 |
ldiv_t ldiv(long n, long m) | 同上,参数为长整数 |
4、数值转换
函数原型 | 意义解释 |
double atof(const char *s) | 由串s构造一个双精度值 |
int atoi(const char *s) | 由串s构造一个整数值 |
long atol(const char *s) | 由串s构造一个长整数值 |
void abort(void);
void exit(int status);
int atexit(void (*fcn)(void))
int system(const char *s);
char *getenv(const char *s);
void *bsearch(const void *key, const void *base, size_t n, size_t size, int (*cmp)(const void *keyval, const void *datum));
void qsort(void *base, size_t n, size_t size, int (*cmp)(const void *, const void *));