有很多工程师喜欢自己封装一些标准库已有的函数,其实自己封装的函数,并不一定比标准库好,有时候反而代码更冗余,且有bug。下面就来分享一下C语言常见的一些标准库。
文件里包含了标准库的一些常用定义,无论我们包含哪个标准头文件,都会被自动包含进来。
类型size_t(sizeof运算符的结果类型,是某个无符号整型);
类型ptrdiff_t(两个指针相减运算的结果类型,是某个有符号整型);
类型wchar_t(宽字符类型,是一个整型,其中足以存放本系统所支持的所有本地环境中的字符集的所有编码值。这里还保证空字符的编码值为0);
宏offsetot (这是一个带参数的宏,第一个参数应是一个结构类型,第二个参数应是结构成员名。
注:其中有些定义也出现在其他头文件里(如NULL)。
定义了一个int类型的表达式errno,可以看作一个变量,其初始值为0,一些标准库函数执行中出错时将它设为非0值,但任何标准库函数都设置它为0。
里还定义了两个宏EDOM和ERANGE,都是非0的整数值。数学函数执行中遇到参数错误,就会将errno置为EDOM,如出现值域错误就会将errno置为ERANGE。
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);
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);
|
|
|
|
|
double pow(double, double)
|
|
double fmod(double, double)
|
注:所有上面未给出类型特征的函数都取一个参数,其参数与返回值都是double类型。
下面函数返回双精度值(包括函数ceil和floor)。在下表里,除其中有特别说明的参数之外,所有函数的其他参数都是double类型。
|
|
|
求出不小于x的最小整数(返回与这个整数对应的double值)
|
|
求出不大于x的最大整数(返回与这个整数对应的double值)
|
|
求出 tan-1(y/x),其值的范围是[-pai,pai]
|
|
|
|
把 x分解为 y*2n, 是位于区间 [1/2,1)里的一个小数,作为函数结果返回,整数n 通过指针*exp返回(应提供一个int变量地址)。当x 为0时这两个结果的值都是0
|
|
把x分解为小数部分和整数部分,小数部分作为函数返回值,整数部分通过指针*ip返回。
|
注:条件成立时这些函数返回非0值。最后两个转换函数对于非字母参数返回原字符。
所有字符串函数列在下表里,函数描述采用如下约定:s、t表示 (char *)类型的参数,cs、ct表示(const char*)类型的参数(它们都应表示字符串)。n表示size_t类型的参数(size_t是一个无符号的整数类型),c是整型参数(在函数里转换到char):
|
|
|
|
|
|
|
把ct里的至多n个字符复制到s。要求s指定一个足够大的字符数组。如果ct里的字符不够n个,就在s里填充空字符。
|
|
把ct里的字符复制到s里已有的字符串之后。s应指定一个保存着字符串,而且足够大的字符数组。
|
|
把ct里的至多n个字符复制到s里已有的字符串之后。s应指定一个保存着字符串,而且足够大的字符数组。
|
|
比较字符串cs和ct的大小,在cs大于、等于、小于ct时分别返回正值、0、负值。
|
|
比较字符串cs和ct的大小,至多比较n个字符。在cs大于、等于、小于ct时分别返回正值、0、负值。
|
|
在cs中查寻c并返回c第一个出现的位置,用指向这个位置的指针表示。当cs里没有c时返回值NULL
|
|
在cs中查寻c并返回c最后一个出现的位置,没有时返回NULL
|
|
由cs起确定一段全由ct里的字符组成的序列,返回其长度
|
|
由cs起确定一段全由非ct里的字符组成的序列,返回其长度
|
|
在cs里查寻ct里的字符,返回第一个满足条件的字符出现的位置,没有时返回NULL
|
|
在cs中查寻串ct(查询子串),返回ct作为cs的子串的第一个出现的位置,ct未出现在cs里时返回NULL
|
|
返回与错误编号n相关的错误信息串(指向该错误信息串的指针)
|
|
|
还有一组字符数组操作函数(存储区操作函数),名字都以mem开头,以某种高效方式实现。在下面原型中,参数s和t的类型是(void *),cs和ct的类型是(const void *),n的类型是size_t,c的类型是int(转换为unsigned char)。
|
|
|
|
|
从ct处复制n个字符到s处,返回s,这里的两个段允许重叠
|
|
比较由cs和ct开始的n个字符,返回值定义同strcmp
|
|
在n个字符的范围内查寻c在cs中的第一次出现,如果找到,返回该位置的指针值,否则返回NULL
|
|
|
|
|
|
|
void srand(unsigned seed)
|
|
|
|
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,此时原块不变
|
|
|
几个简单的整数函数见下表,div_t和ldiv_t是两个预定义结构类型,用于存放整除时得到的商和余数。div_t类型的成分是int类型的quot和rem,ldiv_t类型的成分是long类型的quot和rem。
|
|
|
|
|
|
|
|
ldiv_t ldiv(long n, long m)
|
|
|
|
double atof(const char *s)
|
|
|
|
|
|
导致程序按正常方式立即终止。status作为送给执行环境的出口值,0表示成功结束,两个可用的常数为EXIT_SUCCESS,EXIT_FAILURE。
int atexit(void (*fcn)(void))
可用本函数把一些函数注册为结束动作。被注册函数应当是无参无返回值的函数。注册正常完成时atexit返回值0,否则返回非零值。
int system(const char *s);
把串s传递给程序的执行环境要求作为系统命令执行。如以NULL为参数调用,函数返回非0表示环境里有命令解释器。如果s不是NULL,返回值由实现确定。
char *getenv(const char *s);
从执行环境中取回与字符串s相关联的环境串。如果找不到就返回NULL。本函数的具体结果由实现确定。在许多执行环境里,可以用这个函数去查看“环境变量”的值。
void *bsearch(const void *key, const void *base, size_t n, size_t size, int (*cmp)(const void *keyval, const void *datum));
函数指针参数cmp的实参应是一个与字符串比较函数strcmp类似的函数,确定排序的顺序,当第一个参数keyval比第二个参数datum大、相等或小时分别返回正、零或负值。
qsort对于比较函数cmp的要求与bsearch一样。设有数组base[0],...,base[n-1],元素大小为size。用qsort可以把这个数组的元素按cmp确定的上升顺序重新排列。
void qsort(void *base, size_t n, size_t size, int (*cmp)(const void *, const void *));
硬核妹子的创意设计:舌头控制器
推荐给初学者:如何学好C语言?
干货:嵌入式C语言源代码优化方案(非编译器优化)
若觉得文章不错,转发分享,也是我们继续更新的动力。
5T资源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、单片机、等等!
在公众号内回复「更多资源」,即可免费获取,期待你的关注~