C标准库源码解剖(12):浮点数环境fenv.h
为了编写高精度浮点数的运算,编程人员需要控制浮点数环境的各个方面:结果如何舍入,浮点数表达式如何简化与变换,如何处理浮点数异常(如下溢之类的浮点数异常是忽略还是产生错误),等等。C99引入了fenv.h来控制浮点数环境。
1、fenv.h:
定义了浮点数环境控制函数、异常控制函数、舍入方式控制函数、浮点数异常码和舍入方式等。注意浮点数环境的实现是依赖于体系结构的,因为不同的体系结构有不同的浮点数指令集。依赖于体系结构的定义放在bits/fenv.h中,这里是x86体系结构的版本(Linux下)。
标准头文件fenv.h内容如下:
/* ISO C99 7.6: 浮点数环境 <fenv.h> */
#ifndef _FENV_H
#define _FENV_H 1
#include <features.h>
/* 获取依赖于体系结构的定义。应该要有下面这些定义:
fenv_t 表示浮点数环境的类型
FE_DFL_ENV fenv_t *指针类型的值,表示浮点数环境的缺省值(用于需要fenv_t参数的函数中)
fexcept_t 表示浮点数异常标志(这个标志保存了浮点数的状态)的类型
下面的宏被定义,当且仅当实现支持这些宏时:
FE_INEXACT 不精确的结果
FE_DIVBYZERO 除数为0
FE_UNDERFLOW 结果向下溢出
FE_OVERFLOW 结果向上溢出
FE_INVALID 无效的运算
FE_ALL_EXCEPT 所有被支持的异常的按位或
下面这些宏被定义,当且仅当实现支持某些适当的舍入方式时:
FE_TONEAREST 最近舍入
FE_UPWARD 向正无穷大(+Inf)舍入
FE_DOWNWARD 向负无穷大(-Inf)舍入
FE_TOWARDZERO 向0舍入
*/
#include <bits/fenv.h>
__BEGIN_DECLS
/* 浮点数异常处理 */
/* 清除EXCEPTS表示的异常状态 */
extern int feclearexcept (int __excepts) __THROW;
/* 将实现定义的异常标志EXCEPTS保存到FLAGP所指的对象中 */
extern int fegetexceptflag (fexcept_t *__flagp, int __excepts) __THROW;
/* 产生由EXCEPTS表示的异常 */
extern int feraiseexcept (int __excepts) __THROW;
/* 根把EXCEPTS异常标志设置为FLAGP所指对象中的值 */
extern int fesetexceptflag (__const fexcept_t *__flagp, int __excepts) __THROW;
/* 确定EXCEPTS指示的各个异常中有哪个异常子集被设置了 */
extern int fetestexcept (int __excepts) __THROW;
/* 舍入控制 */
/* 获得当前的舍入方向,表示为一个舍入
相关文档:
Delphi 与 C/C++ 数据类型对照表
Delphi数据类型C/C++
ShorInt
8位有符号整数
char
Byte
8位无符号整数
BYTE,unsigned short
SmallInt
16位有符号整数
short
Word
16位无符号整数
unsigned short
Integer,LongInt
32位有符号整数
int,long
Cardinal,LongWord/DWORD
32位无符号整数
unsigned long
Int6 ......
C6000系列DSP的硬件资源为高性能提高了必要条件,TI公司也配合C6000推出了世界上第一个效率可达70%~80%的汇编语言级C编译器,它产生的代码平均效率是以往DSP编译器的3倍,如何理解并充分利用这些有利资源,使代码达到所期望的性能,是本章的主题。
① 第一阶段:属于纯C阶段,此时不需要 ......
华为C/C++笔试题2 收藏
1. 某32位系统下, C++程序,请计算sizeof 的值
#include <stdio.h>
#include <malloc.h>
void Foo ( char str[100] )
{
printf("sizeof(str)=%d \n", sizeof(str) );//此处使用char *str与char str[100]是一样的,char str[100]不指明大小(char str[]) ......
1. 找错
#define MAX_SRM 256
DSN get_SRM_no()
{
static int SRM_no;
int I;
for(I=0;I<MAX_SRM;I++,SRM_no++)
{
SRM_no %= MAX_SRM;
......
一位同学整理的常见笔试/面试题目,答案仅供参考,不代表本人观点。
这个东西有些参考价值,和同学讨论一下发现还是有些错误,
1.已知strcpy函数的原型是:
char * strcpy(char * strDest,const char * strSrc);
1.不调用库函数,实现strcpy函数。
2.解释为什么要返回char *。
解说:
1.strcpy的实现代码
char * st ......