当前位置: 首页 > news >正文

C语言从头学58——学习头文件math.h(一)

       math.h 头文件提供了很多数学计算方面的函数。
一、使用数学函数前需要了解的两个类型、两个宏
  1、float_t:当前系统能够有效执行float运算的类型,宽度不少于float。
  2、double_t:当前系统能够有效执行double运算的类型,宽度不少于double。
  (使用系统的float_t、double_t的宽度见例子)
  3、INFINITY:该宏表示正无穷(表示计算出来的结果太大无法显示)
  4、NAN :该宏表示非数字(表示计算出来的结果不能用数字表示)
二、数学函数计算过程中发生错误时报错类型方式:
   Range errors:函数返回类型无法表示运算结果
   Domain errors:函数参数错误
   Pole errors:参数导致函数的极限值变成无限
   Overflow errors:运算结果太大向上溢出
   Underflow errors:运算结果太小向下溢出
三、判断参数是否存在错误的几个函数
   1、fpclassify(参1);
        参数: 参1:int、float、double等类型的值或表达式
        返回值:
        a.当参数(值或表达式)为正无穷大或负无穷大时返回FP_INFINITE
        b.当参数不是数字时返回FP_NAN
        c.当参数为零时返回FP_ZERO
        d.当参数为正或负非正常值时返回FP_SUBNORMAL
        e.当参数为非零的、正常值时返回FP_NORMAL
    2、isfinite(参1);
         参数:参1:int、float、double等类型的值或表达式
         返回值:如果参数不是无限或 NAN,返回1(真),否则返回0。
    3、isinf(参1); 
         参数:参1:int、float、double等类型的值或表达式
         返回值:如果参数是正无穷或负无穷,返回1(真),否则返回0。
    4、isnan(参1); 
         参数:参1:int、float、double等类型的值或表达式
         返回值:如果参数不是数字,返回1(真),否则返回0。
    5、isnormal(参1);
         参数:参1:int、float、double等类型的值或表达式
         返回值:如果参数是正常数字,返回1(真),否则返回0。
         说明:
        a.使用以上一个或几个函数特别是第1个函数,对数学函数的参数进行一下检验,再正式
调用数学函数,可以避免出现计算错误。
       b.现在的编译器很聪明,等不到程序发现错误编译器就提前发现了。
    6、signbit(参1); 
         参数:参1:int、float、double等类型的值或表达式
         返回值:如果参数为负值返回非0数,否则返回0。
四、很多数学函数的返回值是 double 类型,但是同时提供 float 类型与long double类型的版本,这种版本就是在函数名后边加上f或者l,函数是否有这种版本,一试便知。acos()函数,还同时存在acosf()和acosl()。
五、验证程序:

#include<stdio.h>
#include<math.h>
char* myFpclassify(double x)
{switch (fpclassify(x)) {case FP_INFINITE:return "参数为正无穷大或符无穷大";break;case FP_NAN:return "参数不是数字\n";break;case FP_ZERO:return "参数是零";break;case FP_SUBNORMAL:return "参数不是正常数字";break;case FP_NORMAL:return "参数是正常数字";break;default:return "参数无法判断";}
}
int main()
{ //float_t、double_t的宽度printf("float_t sizeof:%d\n", (int)sizeof(float_t));//运行结果:float_t sizeof:4printf("float sizeof:%d\n", (int)sizeof(float));//运行结果:float sizeof:4printf("double_t sizeof:%d\n", (int)sizeof(double_t));//运行结果:double_t sizeof:8printf("double sizeof:%d\n", (int)sizeof(double));//运行结果:double sizeof:8printf("INFINITY:%f\n", INFINITY);//运行结果:INFINITY:infprintf("NAN:%f\n", NAN); //运行结果:NAN:nan
//实验fpclassify函数char* s = myFpclassify(1.0 / 1.2e300); //运行结果:参数是正常数字printf("%s\n", s);s = myFpclassify(0.0 / 1.2e300); //运行结果:参数是零printf("%s\n", s); 
//实验signbit函数printf("-3.14signbit:%d 3.14signbit:%d\n", signbit(-6.28), signbit(3.14));//运行结果: -3.14signbit:32768 3.14signbit:0
//数学函数版本printf("acos(0.145)=%.10f\n",acos(0.145));//运行结果:acos(0.145)=1.4252833543printf("acosf(0.145)=%.10f\n",acosf(0.145));//运行结果:acosf(0.145) = 1.4252833128printf("acosl(0.145)=%.10f\n",acosl(0.145));//运行结果:acosl(0.145) = 1.4252833543getchar();return 0;
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 基于深度学习的蛋白质结构预测
  • 【spring】 Jackson :@JsonIgnore 注解
  • 校园二手数码交易系统小程序的设计
  • nnunetv2系列:torch转onnx
  • AI学习指南深度学习篇-带动量的随机梯度下降法Python实践
  • 技术美术一百问(01)
  • 基于CNN-BiGUR的恶意域名检测方法
  • IDC基础学习笔记
  • Pycharm Remote Development 报错解决
  • HTTP 协议和 APACHE 服务
  • TikTok运营需要的独立IP如何获取?
  • Redis 入门 - 五大基础类型及其指令学习
  • 代码随想录冲冲冲 Day41 动态规划Part9
  • Mysql | 知识 | 事务隔离级别
  • Kylin Server V10 下 MySQL 8 binlog 管理
  • Angular2开发踩坑系列-生产环境编译
  • Docker入门(二) - Dockerfile
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • iBatis和MyBatis在使用ResultMap对应关系时的区别
  • Javascript设计模式学习之Observer(观察者)模式
  • js如何打印object对象
  • js写一个简单的选项卡
  • Laravel核心解读--Facades
  • Python代码面试必读 - Data Structures and Algorithms in Python
  • Python中eval与exec的使用及区别
  • SpiderData 2019年2月25日 DApp数据排行榜
  • Spring声明式事务管理之一:五大属性分析
  • 包装类对象
  • 关于Android中设置闹钟的相对比较完善的解决方案
  • 使用 5W1H 写出高可读的 Git Commit Message
  • 推荐一个React的管理后台框架
  • #[Composer学习笔记]Part1:安装composer并通过composer创建一个项目
  • #include<初见C语言之指针(5)>
  • #pragma pack(1)
  • #systemverilog# 之 event region 和 timeslot 仿真调度(十)高层次视角看仿真调度事件的发生
  • $.ajax()方法详解
  • %@ page import=%的用法
  • (4.10~4.16)
  • (C#)Windows Shell 外壳编程系列9 - QueryInfo 扩展提示
  • (ctrl.obj) : error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MDd_DynamicDebug”不匹配值“
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (二)Linux——Linux常用指令
  • (二)linux使用docker容器运行mysql
  • (附源码)php投票系统 毕业设计 121500
  • (七)c52学习之旅-中断
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (杂交版)植物大战僵尸
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • .axf 转化 .bin文件 的方法
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .net core 6 集成 elasticsearch 并 使用分词器
  • .NET delegate 委托 、 Event 事件
  • .Net(C#)常用转换byte转uint32、byte转float等
  • .NET/ASP.NETMVC 大型站点架构设计—迁移Model元数据设置项(自定义元数据提供程序)...
  • .NET处理HTTP请求