7<stddef.h>:

NULL

size_t

wchar_t

ptrdiff_t    指针之间的差值

size_t offsetof(structName,memberName); 结构成员相对于结构的偏移量

INT_MAX

INT_MIN

UINT_MAX

long

LONG_MAX

LONG_MIN

ULONG_MAX

8<time.h>

NULL

size_t

CLOCKS_PER_SEC          每秒的时钟数

CLK_TCK                 每秒的时钟数被CLOCKS_PER_SEC代替

clock_t     clock函数的返回类型表示进程的逝去时钟数

time_t      time等函数的返回值表示日历时间

struct tm

{

int tm_sec;    秒(0-59)

int tm_min;    分钟(0-59)

int tm_hour;   小时(0-24)

int tm_mday;   月中的天数(多少号)(1-31)

int tm_mon;    月份(0-11)

int tm_year;   年份从1900年开始

int tm_wday;   星期(0-6,星期日=0)

int tm_yday;   一年中的日期(0-365,1月1号 = 0)

int tm_isdst; 夏令时(正数有效,0无效,负数未定义)

};

返回调用进程使用的时钟数

clock_t clock(void);

获取系统时间(从1970,1,1 00:00:00 开始到现在的的秒数)

timer可以为NULL表示只返回不存储

time_t time(time_t *timer);

返回两个时间的差值

double difftime(time_t time1, time_t time2);

将time_t转换成字符串

char *ctime(const time_t *timer);

转换一个时间值有time_t转换到struct tm

struct tm *locattime(const time_t *timer);

gmtime使用UTC世界时间代码而不是本地时间

struct tm *gmtime(const time_t *timer);

将struct tm转换成time_t

time_t mktime(struct tm *timer);

localtime gmtime mktime使用同一个struct tm静态结构.每次调用前都清除其中的容

将struct tm转换成字符串

char *asctime(const struct tm *timer);

格式化一个时间字符串

size_t strftime(char *dest,size_t size,const char *format,

const struct tm *timer);

9<float.h>:

<float.h>与<limits.h>一样是定义边界值的,<float.h>定义的是浮点数的边界值

double

DBL_DIG            double小数点后面精确的位数

DBL_EPSILON        小的正数,double的0跨度值

DBL_MANT_DIG       尾数中的位数

DBL_MAX            最大值

DBL_MAX_10_EXP     最大10进制指数

DBL_MAX_EXP        最大2进制指数

DBL_MIN            最小值

DBL_MIN_10_EXP     最小10进制指数

DBL_MIN_EXP        最小2进制指数

float

FLT_DIG            float小数点后面精确的位数

FLT_EPSILON        小的正书,float的0跨度值

FLT_MANT_DLG       尾数中的位数

FLT_MAX            最大值

FLT_MAX_10_EXP     最大10进制指数

FLT_MAX_EXP        最大2进制指数

FLT_MIN            最小值

FLT_MIN_10_EXP     最小10进制指数

FLT_MIN_EXP        最小2进制指数

FLT_RADIX          进制基数

FLT_ROUNDS     加法舍入

long double

LDBL_DIG           long double小数点后面精确的位数

LDBL_EPSILON       小的正数,long double的0跨度值

LDBL_MANT_DLG      尾数中的位数

LDBL_MAX           最大值

LDBL_MAX_10_EXP    最大10进制指数

LDBL_MAX_EXP       最大2进制指数

LDBL_MIN           最小值

LDBL_MIN_10_EXP    最小10进制指数

LDBL_MIN_EXP       最小2进制指数

10<math.h>

<math.h>中定义了数学函数

HUGE_VAL       最大的可表示的双精度值,这个值是由许多数学函数错误时返回的,有的函数返回-HUGE_VAL

EDOM           当传递的参数类型或数值错误时errno被赋予这个值

ERANGE         当数值超出浮点数的范围时errno被赋予这个值

三角函数

计算正弦

double sin(double x);

计算双曲线的正弦

double sinh(double x);

计算余弦

double cos(double x);

计算双曲线余弦

double cosh(double x);

计算正切

double tan(double x);

计算双曲线正切

double tanh(double x);

计算反余弦

double acos(double x);

计算反正弦

double asin(double x);

计算反正切

double atan(double x);

计算y/x的反正切

double atan2(double y, double x);

幂函数

计算x的y次幂

double pow(double x, double y);

计算平方根

double sqrt(double x);

计算指数值

double exp(double x);

计算自然对数

double log(double x);

计算以10为底的对数

double log10(double x);

浮点数操作函数

返回大于或等于x的最小整数

double ceil(double x);

计算浮点数的绝对值

double fabs(double x);

返回小于等于x的最大整数

double floor(double x);

计算x/y的余数

double fmod(double x, double y);

获得一个浮点数的尾数和指数

double frexp(double x, int *expptr);

从尾数和指数计算一个实数

double ldexp(double x, int exp);

把一个浮点数分解成小数和整数

double modf(double x, int *intptr);

11<errno.h>

errno          各种错误条件的事件赋予的错误代码如EDOM,ERANGE等

12<locale.h>

一个程序用于指定该程序使用哪一部分场所信息.

NULL

LC_ALL         影响所用的方面

LC_COLLATE     影响字符串校验函数strcoll,strxfrm

LC_CTYPE       影响<ctpye.h>中定义的字符处理函数

LC_MONETARY    影响localeconv返回的钱币格式信息

LC_NUMERIC     影响localeconv返回的非钱币格式的使用小数的数字信息,包括格式化,字符转换等

LC_TIME        影响strftime

struct lconv

{

成员                      “C”场所值场所范围        成员含义

char *currency_symbol;        “”      LC_MONETARY    当前场所的地方货币

符号

char *int_curr_symbol;        “”      LC_MONETARY    当前场所的国际货币

符号

char *mon_decimal_point; “”      LC_MONETARY    货币量的小数点

char *mon_grouping;          “”      LC_MONETARY    货币量每个数字组的

尺寸

char *mon_thousands_sep; “”      LC_MONETARY    货币量小数点左边的

数字分组字符

char *negative_sign;      “”      LC_MONETARY    负货币量表示符号的

字符串

char *positive_sign;      “”      LC_MONETARY    正货币量表示符号的

字符串

char *decimal_point;      “.”     LC_NUMERIC 非货币量的小数点

char *grouping;              “”      LC_NUMERIC 非货币量的每个数字

的尺寸

char *thousands_sep;      “”      LC_NUMERIC 非货币量小数点左边

数字分组字符

char frac_digits;     CHAR_MAX    LC_MONETARY    格式化货币量中小数

点右边的数字位数

char int_frac_digits;     CHAR_MAX    LC_MONETARY    国际格式化货币量中

小数点右边的数字位

char n_cs_precedes;       CHAR_MAX    LC_MONETARY    如果货币符号位于负

格式货币量之前,它

设置为1;如果符号在

值以后,设置为0

char n_sep_by_space; CHAR_MAX    LC_MONETARY    如果货币符号通过空

格从负格式货币量中

分离则设置为1,没有

空格则为0

char n_sign_posn;     CHAR_MAX    LC_MONETARY    负格式货币量值正符

号的位置

char p_cs_precedes;       CHAR_MAX    LC_MONETARY    如果货币符号位于非

负格式货币量之前,

它设置为1,如果符号

值以后,设置为0

char p_sep_by_space; CHAR_MAX    LC_MONETARY    如果货币符号通过空

格从非负格式货币量

中分离则设置为1,没

有空格为0

char p_sign_posn;     CHAR_MAX    LC_MONETARY    非负格式货币量值正

符号的位置

};

结构中的char *成员等于””的长度为0或不被当前场所支持,char成员为非负数CHAR_MAX的不被当前场所支持.

获得场所设置的详细信息

struct lconv *localeconv(void);

定义一个场所

char *setlocale(int category,const char *locale);

13<setjmp.h>

jmp_buf     setjmp和longjmp使用的类型,用来保存和恢复应用程序环境

保存当前应用程序的环境

int setjmp(jmp_buf env);

恢复栈环境和执行场所

void longjmp(jmp_buf env, int val);

这两个函数的使用是有顺序性的一定是先调用setjmp来存储环境变量,再通过longjmp来恢复环境变量

它的执行过程是这样的(:前面的时行号)

#include <stdio.h>

#include <setjmp.h>

jmp_buf ebuf;

void f2(void);

int main(void)

{

int i;

puts("1");

0:   i = setjmp(ebuf);

1:   if(i == 0)

{

2:      f2();

3:      printf("This will not be printed");

}

4:   printf("%d\n",i);

return 0;

}

void f2(void)

{

5:   puts("2");

6:   longjmp(ebuf,100);

}

上面的函数的执行过程是这样的

0行第一次执行setjmp时ebuf中保存了当前的系统环境变量,并返回0.接下来执行第1行,这是i等于0,执行第2行由次进入了f2中,第五行向stdout中打印了2,然后第6行调用了longjmp恢复了系统环境变量,注意这时函数的执行又回到了第0行而不是执行f2后面的第3行,这时setjmp返回的函数就不是0了而是longjmp中的100,所以接下来执行的第1行中的i等于100了直接执行第4行.所以第3行永远也没有机会执行.

14<signal.h>

信号

SIGABRT     异常中止,缺省动作是推出程序并返回推出码3

SIGFPE      浮点错误,例如溢出,除0或无效操作,缺省终止程序

SIGILL      非法指令,缺省终止程序

SIGINT      CTRL+C中断,缺省调用INT23H中断

SIGSEGV     非法存储访问,缺省终止程序

SIGTERM     终止请求传送到程序,缺省终止程序

行为

SIG_DFL     使用系统缺省响应,如果调用程序使用流I/O,由运行库建立缓冲区不刷新.

SIG_IGN     忽略中断信号,这个值从不会为SIGFPE给出,因为该进程的浮点状态无定义

SIG_ERR     错误.

sig_atomic_t

发送一个信号给应用程序,如果以前使用signal安装了一个信号处理程序则执行该程序,没有则执行信号的缺省行为

int raise(int sig);

设置中断信号处理,signo是中断要处理的信号,必须是上面的信号之一,func是处理函数的地址或者使用上面的行为,如果func是函数的地址,则这个函数在调用signal时就被安装.

void (*signal(int signo,void(*func)(int)))(int);

按照如下的方法使用signal函数

#include <stdio.h>

#include <setjmp.h>

#include <signal.h>

#include <stdlib.h>

jmp_buf env;

void fpHander(int signo);

int main(void)

{

int jmpflag;

double d1,d2,r;

0:   if(signal(SIGFPE,fpHander) == SIG_ERR)

{

perror("Can't install the SIGFPE hander");

abort();

}

else

{

jmpflag = setjmp(env);

if(jmpflag == 0)

{

printf("Test for div:");

scanf("%lf%lf",&d1,&d2);

1:          r = d1/d2;

printf("r:%G\n",r);

printf("d2 is not 0\n");

r = d1*d2*d2*d1*d2*d2;

2:          printf("r:%G\n",r);

printf("r is not overflow\n");

3:          if(d2 == 0)

4:              raise(SIGFPE);

}

else

{

printf("Signal fixed\n");

}

}

return 0;

}

void fpHander(int signo)

{

printf("signo:%d\n",signo);

longjmp(env,-1);

}

一般的如果读入的d2为0的话,那么当执行第1行时就会引发浮点错误信号SIGFPE,而代用第0行安装的函数fpHander(但是在VC中好像不行,但TC中能通过)如果不能引发SIGFPE只好自己来引发SIGFPE了第4行调用了raise来引发SIGFPE错误使fpHander函数执行.

15<stdarg.h>

在这个头文件中定义了一些宏和类型,用来实现可变参数函数.

va_list     可变参数表类型.

va_start    设置可变参数表头的宏

va_arg      检索当前参数的宏

va_end      清除可变参数列表的宏,是的函数能够返回

(转)The Standard C Library 经典的基础(下)相关推荐

  1. (转)The Standard C Library 经典的基础(上)

    The Standard C Library 经典的基础 C的标志库函数是学习和使用C语言的基础,是编写经典C程序的基础,是学习其他计算机知识的基础.C标志库中一共包含了15个头文件: <ass ...

  2. 标准模板库STL(Standard Template Library)

    标准模板库STL(Standard Template Library)指南 /*刘振飞liuzf@pku.org.cn 1999-10-20*/ / *版权所有 (C) 1999-2004 刘振飞li ...

  3. STA series --- 3.Standard cell library(PART-II)

    序: 本篇内容,基于阅读J. Bhasker • Rakesh Chadha著作<Static Timing Analysis for Nanometer Designs>后进行的总结以及 ...

  4. Thread Safety in the Standard C++ Library

    2019独角兽企业重金招聘Python工程师标准>>> Thread Safety in the Standard C++ Library When  /MT , /MTd, /MD ...

  5. Standard C Library - 思维火花 - 博客频道 - CSDN.NET

    Standard C Library - 思维火花 - 博客频道 - CSDN.NET « DIY 了一套 ACQUIRE | 返回首页 | 骨骼动画的插值与融合 » 动态数组的 C 实现 上次谈到了 ...

  6. STM32 Tips:如何从ST官方网站上下载STM32标准外设库(STM32F10x standard peripheral library)

    入手了一块STM32F107VCT6开发板,配置开发环境时需要一个库:STM32F10x标准外设库(STM32F10x standard peripheral library),在网上看到很多初学者和 ...

  7. STM32 标准外设库(Standard Peripheral Library)下载

    STM32 标准外设库(Standard Peripheral Library)下载. 一.链接 STM32 Standard Peripheral Libraries - STMicroelectr ...

  8. STL序列式容器Standard Template Library Sequence Container

    STL序列式容器 STL Sequence Container 目录 STL序列式容器 STL Sequence Container STL(Standard Template Library)概述 ...

  9. java标签库 taglib pdf格式_JSP系列教材 (十)- JSTL Java Standard Tag Library 标准标签库...

    JSTL JSP Standard Tag Library 标准标签库 JSTL允许开人员可以像使用HTML标签 那样在JSP中开发Java功能. JSTL库有core, i18n, fmt, sql ...

最新文章

  1. Upgrade after a crash is not supported. The redo log was created with Maria的解决办法
  2. PostgreSQL学习手册(数据表)
  3. 【snmp】测试流程
  4. JavaScript中的私有函数;Javascript构造函数的私有方法中访问其属性和公有方法
  5. python经典程序实例-Python简单基础小程序的实例代码
  6. 访问共享文件时切换默认的访问账号
  7. linux下槽函数的响应时间,Qt信号与槽之connectSlotsByName函数
  8. 华为设备DHCP/DHCP中继及DHCPv6/DHCPv6中继详解
  9. 苹果系统中英文输入法切换_苹果输入法怎么切换_苹果系统如何切换输入法-win7之家...
  10. Date()常用方法getMonth, getFullYear等
  11. 智鼎在线测评是测什么_(详解)人才测评工具和人才测评方法
  12. 跨界融合 | 零数科技正式成为上海现代服务业联合会会员单位
  13. 老男孩教育python全栈第九期视频
  14. html5倒计时秒杀怎么做,如何让秒杀、活动倒计时更精确?
  15. mac蓝牙连接有问题要怎么处理呢?
  16. 心理测评软件php mysql_心理测量软件_心理测评系统
  17. 软件测试的自我修养之学习自动化测试
  18. Linux学习(CentOS-7)---Linux开机流程
  19. vue监听滚动到底部加载更多
  20. Asterisk支持通话录音前语音提示

热门文章

  1. 链路层 - SLIP,PPP,
  2. hausaufgabe--python 20- usage of Closure
  3. Java核心技术卷I基础知识1.2.7 可移植性
  4. GlobalSign 团队与世界领先的认证机构(CAs)合作 共同加强网络安全
  5. 那些年移动互联网行业曾经走过的弯路
  6. eclipse菜单解释及中英对照《二》
  7. Oracle发布Oracle数据库的官方Node.js驱动node-oracledb
  8. 虚拟化Hadoop集群的部署和管理 - 基本操作
  9. 永中Office—给公文设置密码
  10. ZooKeeper(一)linux上单机与集群的搭建