热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

最常用标准库函数(转)

最常用标准库函数标准头文件包括:<asset.h><ctype.h><errno.h><float.h>

最常用标准库函数

标准头文件包括:

                      

                    

                

           

标准定义(

文件里包含了标准库的一些常用定义,无论我们包含哪个标准头文件,都会被自动包含进来。这个文件里定义:

         类型size_t(sizeof运算符的结果类型,是某个无符号整型);

         类型ptrdiff_t(两个指针相减运算的结果类型,是某个有符号整型);

         类型wchar_t(宽字符类型,是一个整型,其中足以存放本系统所支持的所有本地环境中的字符     集的所有编码值。这里还保证空字符的编码值为0);

        符号常量NULL(空指针值);

         宏offsetor(这是一个带参数的宏,第一个参数应是一个结构类型,第二个参数应是结构成员名。offsetor(s,m)求出成员m在结构类型t的变量里的偏移量)。

其中有些定义也出现在其他头文件里(如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);  把字符 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

指数和对数函数:

以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返回。

字符处理函数(),见下表:

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值。最后两个转换函数对于非字母参数返回原字符。

字符串函数(

字符串函数

所有字符串函数列在下表里,函数描述采用如下约定:s、t表示 (char *)类型的参数,cs、ct表示(const char*)类型的参数(它们都应表示字符串)。n表示size_t类型的参数(size_t是一个无符号的整数类型),c是整型参数(在函数里转换到char):

函数原型

意义解释

size_t strlen(cs)

求出cs的长度(不包含‘\0’),如strlen(chai)=4

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中的字符作为分隔符而形成的单词

存储区操作

还有一组字符数组操作函数(存储区操作函数),名字都以mem开头,以某种高效方式实现。在下面原型中,参数s和t的类型是(void *),cs和ct的类型是(const void *),n的类型是size_t,c的类型是int(转换为unsigned char)。

函数原型

意义解释

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为随后的随机数生成设置种子值

动态存储分配函数:

函数原型

意义解释

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)

释放以前分配的动态存储块

几个整数函数

几个简单的整数函数见下表,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)

同上,参数为长整数

数值转换

函数原型

意义解释

double atof(const char *s)

由串s构造一个双精度值

int atoi(const char *s)

由串s构造一个整数值

long atol(const char *s)

由串s构造一个长整数值

执行控制

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,否则返回非零值。

与执行环境交互

1)向执行环境传送命令的函数system。原型是:

int system(const char *s);

把串s传递给程序的执行环境要求作为系统命令执行。如以NULL为参数调用,函数返回非0表示环境里有命令解释器。如果s不是NULL,返回值由实现确定。

2)访问执行环境的函数getenv。原型是:

char *getenv(const char *s);

从执行环境中取回与字符串s相关联的环境串。如果找不到就返回NULL。本函数的具体结果由实现确定。在许多执行环境里,可以用这个函数去查看“环境变量”的值。

常用函数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:

void qsort(void *base, size_t n, size_t size,

int (*cmp)(const void *, const void *));

qsort对于比较函数cmp的要求与bsearch一样。设有数组base[0],...,base[n-1],元素大小为size。用qsort可以把这个数组的元素按cmp确定的上升顺序重新排列。

 

#include

成员函数

  • empty()判断队列空,当队列空时,返回true。
  • size()访问队列中的元素个数。
  • push()会将一个元素置入queue中。
  • front()会返回queue内的第一个元素(也就是第一个被置入的元素)。
  • back()会返回queue中最后一个元素(也就是最后被插入的元素)。
  • pop()会从queue中移除一个元素。
  • 注意:pop()虽然会移除下一个元素,但是并不返回它,front()和back()返回下一个元素但并不移除该元素。
#include头文件,STL中的很有用的容器适配器之一,默认基于Deque容器实现,可以在定义时覆盖其默认容器类型,但一般并不需要。
包含以下几个成员函数:
empty() 堆栈为空则返回真
pop() 移除栈顶元素(不会返回栈顶元素的值)
push() 在栈顶增加元素
size() 返回栈中元素数目
top() 返回栈顶元素

推荐阅读
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 本文介绍了在PostgreSQL中批量导入数据时的优化方法。包括使用unlogged表、删除重建索引、删除重建外键、禁用触发器、使用COPY方法、批量插入等。同时还提到了一些参数优化的注意事项,如设置effective_cache_size、shared_buffer等,并强调了在导入大量数据后使用analyze命令重新收集统计信息的重要性。 ... [详细]
  • 本文介绍了利用ARMA模型对平稳非白噪声序列进行建模的步骤及代码实现。首先对观察值序列进行样本自相关系数和样本偏自相关系数的计算,然后根据这些系数的性质选择适当的ARMA模型进行拟合,并估计模型中的位置参数。接着进行模型的有效性检验,如果不通过则重新选择模型再拟合,如果通过则进行模型优化。最后利用拟合模型预测序列的未来走势。文章还介绍了绘制时序图、平稳性检验、白噪声检验、确定ARMA阶数和预测未来走势的代码实现。 ... [详细]
  • 本文介绍了使用C++Builder实现获取USB优盘序列号的方法,包括相关的代码和说明。通过该方法,可以获取指定盘符的USB优盘序列号,并将其存放在缓冲中。该方法可以在Windows系统中有效地获取USB优盘序列号,并且适用于C++Builder开发环境。 ... [详细]
  • 题目描述Takuru是一名情报强者,所以他想利用他强大的情报搜集能力来当中间商赚差价。Takuru的计划是让Hinae帮他去市场上买一个商品,然后再以另一个价格卖掉它。Takur ... [详细]
  • DescriptionclickmeSolution套路的状压期望DP题。。。考虑倒退期望:设fi,jrolepresentationstyleposi ... [详细]
  • 开发笔记:城市建设
    本文由编程笔记#小编为大家整理,主要介绍了城市建设相关的知识,希望对你有一定的参考价值。本文涉及:cdq分治、MST一道十分精妙的cdq分 ... [详细]
  • 题面传送门Solution看到什么最大值最小肯定二分啊。check直接跑一个二分图匹配就好了。orzztl!!!代码实现*mail:mle ... [详细]
  • 目录题目来源题目描述输入描述输出描述用例题目解析算法源码题目来源20200817-数位DP-带49的数_哔哩哔哩_bilibili题目描述求区间[1,n]范围内包 ... [详细]
  • 为什么即使Linux服务器的socket关闭,客户端仍能调用一次send函数?
    要弄清这个问题,首先需要知道调用send()发送数据时,发生了什么。当调用send()发送数据时,并不是直接将数据发送到网络中,而是先将待发送的数据放到socket发送缓冲区中,然 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
author-avatar
袁沮战_246
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有