有很多工程师喜欢自己封装一些标准库已有的函数,其实自己封装的函数,并不一定比标准库好,有时候反而代码更冗余,且有bug。下面就来分享一下C语言常见的一些标准库。
标准头文件包括:
一、标准定义(
文件
这个文件里定义:
类型size_t(sizeof运算符的结果类型,是某个无符号整型);
类型ptrdiff_t(两个指针相减运算的结果类型,是某个有符号整型);
类型wchar_t(宽字符类型,是一个整型,其中足以存放本系统所支持的所有本地环境中的字符集的所有编码值。这里还保证空字符的编码值为0);
符号常量NULL(空指针值);
宏offsetor(这是一个带参数的宏,第一个参数应是一个结构类型,第二个参数应是结构成员名。
offsetor(s,m)
求出成员m在结构类型t的变量里的偏移量)。
注:其中有些定义也出现在其他头文件里(如NULL)。
二、错误信息(
三、输入输出函数(
文件打开和关闭:
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) intungetc(intc,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);
四、数学函数(
1.三角函数:
三角函数 | 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) |
注:所有上面未给出类型特征的函数都取一个参数,其参数与返回值都是double类型。
下面函数返回双精度值(包括函数ceil和floor)。在下表里,除其中有特别说明的参数之外,所有函数的其他参数都是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本身 |
注:条件成立时这些函数返回非0值。最后两个转换函数对于非字母参数返回原字符。
六、字符串函数(
1.字符串函数
所有字符串函数列在下表里,函数描述采用如下约定:s、t表示 (char *)类型的参数,cs、ct表示(const char*)类型的参数(它们都应表示字符串)。n表示size_t类型的参数(size_t是一个无符号的整数类型),c是整型参数(在函数里转换到char):
函数原型 | 意义解释 |
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中的字符作为分隔符而形成的单词 |
2.存储区操作
函数原型 | 意义解释 |
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 |
七、功能函数(
1.随机数函数:
函数原型 | 意义解释 |
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) | 释放以前分配的动态存储块 |
3.几个整数函数
几个简单的整数函数见下表,div_t和ldiv_t是两个预定义结构类型,用于存放整除时得到的商和余数。div_t类型的成分是int类型的quot和rem,ldiv_t类型的成分是long类型的quot和rem。
函数原型 | 意义解释 |
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构造一个长整数值 |
5.执行控制
1)非正常终止函数abort。
原型是:
void abort(void);
2)正常终止函数exit。
原型是:
void exit(int status);
导致程序按正常方式立即终止。status作为送给执行环境的出口值,0表示成功结束,两个可用的常数为EXIT_SUCCESS,EXIT_FAILURE。
3)正常终止注册函数atexit。
原型是:
int atexit(void (*fcn)(void))
可用本函数把一些函数注册为结束动作。被注册函数应当是无参无返回值的函数。注册正常完成时atexit返回值0,否则返回非零值。
6.与执行环境交互
1)向执行环境传送命令的函数system。
原型是:
int system(const char *s);
把串s传递给程序的执行环境要求作为系统命令执行。如以NULL为参数调用,函数返回非0表示环境里有命令解释器。如果s不是NULL,返回值由实现确定。
2)访问执行环境的函数getenv。
原型是:
char *getenv(const char *s);
从执行环境中取回与字符串s相关联的环境串。如果找不到就返回NULL。本函数的具体结果由实现确定。在许多执行环境里,可以用这个函数去查看“环境变量”的值。
7.常用函数bsearch和qsort
1)二分法查找函数bsearch:
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大、相等或小时分别返回正、零或负值。
2)快速排序函数qsort:
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语言
+关注
关注
180文章
7628浏览量
139918 -
文件
+关注
关注
1文章
577浏览量
25145 -
字符
+关注
关注
0文章
234浏览量
25434 -
函数
+关注
关注
3文章
4365浏览量
63932 -
标准库
+关注
关注
0文章
31浏览量
7639
原文标题:C语言常用标准库
文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
C语言标准库的基本使用
dsPIC语言工具库
单片机常用的C语言标准库有哪些呢
AVR单片机C语言库

C语言常见的一些标准库
C语言的一些常用标准库分享
C 语言使用标准库开发


半导体芯片需要做哪些测试
首先我们需要了解芯片制造环节做⼀款芯片最基本的环节是设计->流片->封装->测试,芯片成本构成⼀般为人力成本20%,流片40%,封装35%,测试5%(对于先进工艺,流片成本可能超过60%)。测试其实是芯片各个环节中最“便宜”的一步,在这个每家公司都喊着“CostDown”的激烈市场中,人力成本逐年攀升,晶圆厂和封装厂都在乙方市场中“叱咤风云”,唯独只有测试显

解决方案 | 芯佰微赋能示波器:高速ADC、USB控制器和RS232芯片——高性能示波器的秘密武器!
示波器解决方案总述:示波器是电子技术领域中不可或缺的精密测量仪器,通过直观的波形显示,将电信号随时间的变化转化为可视化图形,使复杂的电子现象变得清晰易懂。无论是在科研探索、工业检测还是通信领域,示波器都发挥着不可替代的作用,帮助工程师和技术人员深入剖析电信号的细节,精准定位问题所在,为创新与发展提供坚实的技术支撑。一、技术瓶颈亟待突破性能指标受限:受模拟前端

硬件设计基础----运算放大器
1什么是运算放大器运算放大器(运放)用于调节和放大模拟信号,运放是一个内含多级放大电路的集成器件,如图所示:左图为同相位,Vn端接地或稳定的电平,Vp端电平上升,则输出端Vo电平上升,Vp端电平下降,则输出端Vo电平下降;右图为反相位,Vp端接地或稳定的电平,Vn端电平上升,则输出端Vo电平下降,Vn端电平下降,则输出端Vo电平上升2运算放大器的性质理想运算

ElfBoard技术贴|如何调整eMMC存储分区
ELF 2开发板基于瑞芯微RK3588高性能处理器设计,拥有四核ARM Cortex-A76与四核ARM Cortex-A55的CPU架构,主频高达2.4GHz,内置6TOPS算力的NPU,这一设计让它能够轻松驾驭多种深度学习框架,高效处理各类复杂的AI任务。

米尔基于MYD-YG2LX系统启动时间优化应用笔记
1.概述MYD-YG2LX采用瑞萨RZ/G2L作为核心处理器,该处理器搭载双核Cortex-A55@1.2GHz+Cortex-M33@200MHz处理器,其内部集成高性能3D加速引擎Mail-G31GPU(500MHz)和视频处理单元(支持H.264硬件编解码),16位的DDR4-1600/DDR3L-1333内存控制器、千兆以太网控制器、USB、CAN、

运放技术——基本电路分析
虚短和虚断的概念由于运放的电压放大倍数很大,一般通用型运算放大器的开环电压放大倍数都在80dB以上。而运放的输出电压是有限的,一般在10V~14V。因此运放的差模输入电压不足1mV,两输入端近似等电位,相当于“短路”。开环电压放大倍数越大,两输入端的电位越接近相等。“虚短”是指在分析运算放大器处于线性状态时,可把两输入端视为等电位,这一特性称为虚假短路,简称

飞凌嵌入式携手中移物联,谱写全国产化方案新生态
4月22日,飞凌嵌入式“2025嵌入式及边缘AI技术论坛”在深圳成功举办。中移物联网有限公司(以下简称“中移物联”)携OneOS操作系统与飞凌嵌入式共同推出的工业级核心板亮相会议展区,操作系统产品部高级专家严镭受邀作《OneOS工业操作系统——助力国产化智能制造》主题演讲。

ATA-2022B高压放大器在螺栓松动检测中的应用
实验名称:ATA-2022B高压放大器在螺栓松动检测中的应用实验方向:超声检测实验设备:ATA-2022B高压放大器、函数信号发生器,压电陶瓷片,数据采集卡,示波器,PC等实验内容:本研究基于振动声调制的螺栓松动检测方法,其中低频泵浦波采用单频信号,而高频探测波采用扫频信号,利用泵浦波和探测波在接触面的振动声调制响应对螺栓的松动程度进行检测。通过螺栓松动检测

MOS管驱动电路——电机干扰与防护处理
此电路分主电路(完成功能)和保护功能电路。MOS管驱动相关知识:1、跟双极性晶体管相比,一般认为使MOS管导通不需要电流,只要GS电压(Vbe类似)高于一定的值,就可以了。MOS管和晶体管向比较c,b,e—–>d(漏),g(栅),s(源)。2、NMOS的特性,Vgs大于一定的值就会导通,适合用于源极接地时的情况(低端驱动),只要栅极电压达到4V或10V就可以

压敏(MOV)在电机上的应用剖析
一前言有刷直流电机是一种较为常见的直流电机。它的主要特点包括:1.结构相对简单,由定子、转子、电刷和换向器等组成;2.通过电刷与换向器的接触来实现电流的换向,从而使电枢绕组中的电流方向周期性改变,保证电机持续运转;3.具有调速性能较好等优点,可以通过改变电压等方式较为方便地调节转速。有刷直流电机在许多领域都有应用,比如一些电动工具、玩具、小型机械等。但它也存

硬件原理图学习笔记
这一个星期认真学习了硬件原理图的知识,做了一些笔记,方便以后查找。硬件原理图分为三类1.管脚类(gpio)和门电路类输入输出引脚,上拉电阻,三极管与门,或门,非门上拉电阻:正向标志作用,给悬空的引脚一个确定的状态三极管:反向三极管(gpio输出高电平,NP两端导通,被控制端导通,电压为0)->NPN正向三极管(gpio输出低电平,PN两端导通,被控制端导通,

TurMass™ vs LoRa:无线通讯模块的革命性突破
TurMass™凭借其高传输速率、强大并发能力、双向传输、超强抗干扰能力、超远传输距离、全国产技术、灵活组网方案以及便捷开发等八大优势,在无线通讯领域展现出强大的竞争力。

RZT2H CR52双核BOOT流程和例程代码分析
RZT2H是多核处理器,启动时,需要一个“主核”先启动,然后主核根据规则,加载和启动其他内核。本文以T2H内部的CR52双核为例,说明T2H多核启动流程。

干簧继电器在RF信号衰减中的应用与优势
在电子测试领域,RF(射频)评估是不可或缺的一部分。无论是研发阶段的性能测试,还是生产环节的质量检测,RF测试设备都扮演着关键角色。然而,要实现精准的RF评估,测试设备需要一种特殊的电路——衰减电路。这些电路的作用是调整RF信号的强度,以便测试设备能够准确地评估RF组件和RF电路的各个方面。衰减器的挑战衰减器的核心功能是校准RF信号的强度。为了实现这一点,衰

ElfBoard嵌入式教育科普|ADC接口全面解析
当代信息技术体系中,嵌入式系统接口作为数据交互的核心基础设施,构成了设备互联的神经中枢。基于标准化通信协议与接口规范的技术架构,实现了异构设备间的高效数据交换与智能化协同作业。本文选取模数转换接口ADC作为技术解析切入点,通过系统阐释其工作机理、性能特征及重要参数,为嵌入式学习者爱好者构建全维度接口技术认知框架。
评论