C语言从头学55——学习头文件errno.h、float.h

1、头文件 errno.h 中的变量 errno 的使用
       在 errno.h 定义了一个 int 类型的变量 errno(错误码),如果发现这个变量出现非零值,表示已经执行的函数发生了错误。这个变量一般多用于检查数学函数运算过程中发生的错误。
       如果要检查某个函数是否发生错误,必须在即将调用该函数之前,将 errno 的值先置为0,防止误用以前的结果。
       我们可以使用两个宏 EDOM 或 ERANGE 来判断发生了什么样的错误。如果 errno 等于EDOM:表示输入的参数发生了错误,将不允许传入的值传进了函数;如果 errno=ERANGE:表示返回值太大,无法接收。
       errno 变量反应的是系统函数使用过程中发生的错误,自定义函数中并没有处理errno变量的语句,所以不会对 errno 有反应。
2、头文件 float.h
       float.h 定义了一些宏,这些宏是关于float、double、long double等类型的范围和精度。我们通过获取这些宏的值,可以了解当前系统中关于浮点类型的相关情况。这些宏对于计算机爱好者编程而言使用上的概率很低,可作为知识了解一下。
   a. FLT_ROUNDS 表示当前浮点数加法的四舍五入方向。查询它的值,和下面的含义对比:
      -1:无法确定
      0:向零舍入。
      1:向最近的整数舍入。
      2:向正无穷方向舍入。
      3:向负无穷方向舍入。
   b. FLT_RADIX 表示科学计数法的指数部分的底(base)
   c. 浮点类型的最大值
      float最大值:FLT_MAX
      double最大值:DBL_MAX
      long double最大值:LDBL_MAX
   d. 浮点数类型的最小正值
      float最小正值:FLT_MIN
      double最小正值:DBL_MIN
      long double最小正值:LDBL_MIN
   e. 两个同类型浮点数之间可表示的最小差值(最小精度)
      float最小差值:FLT_EPSILON
      double最小差值:DBL_EPSILON
      long double最小差值:LDBL_EPSILON
   f. DECIMAL_DIG 表示十进制有效位数。
   h. FLT_EVAL_METHOD 表示浮点数运算时的类型转换。查询它的值,和下面的含义对比:
      -1:无法确定
      0:在当前类型中运算
      1:float和double类型运算时使用double类型的范围和精度求值
      2:所有浮点数类型的运算都使用long double类型的范围和精度求值
   i. 浮点数尾数部分的个数
     float类型:FLT_MANT_DIG
     double类型:DBL_MANT_DIG
     long double类型:LDBL_MANT_DIG
   j. 浮点数指数部分有效数字的个数(十进制)
     float类型:FLT_DIG
     double类型:DBL_DIG
     long double类型:LDBL_DIG
   k. 科学计数法的指数部分的最小次幂(负数)
     float类型:FLT_MIN_EXP
     double类型:DBL_MIN_EXP
     long double类型:LDBL_MIN_EXP
   l. 科学计数法的指数部分的十进制最小次幂(负数)
     float类型:FLT_MIN_10_EXP
     double类型:DBL_MIN_10_EXP
     long double类型:LDBL_MIN_10_EXP
   m. 科学计数法的指数部分的最大次幂
    float类型:FLT_MAX_EXP
    double类型:DBL_MAX_EXP
    long double类型:LDBL_MAX_EXP
   n. 科学计数法的指数部分的十进制最大次幂
    float类型:FLT_MAX_10_EXP
    double类型:DBL_MAX_10_EXP
    long double:LDBL_MAX_10_EXP
3、利用计算机程序查询一下本机中各种宏的值。

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<errno.h>
#include<math.h> //使用数学公式需包含
#include<float.h>int main(void)
{
//实验errno变量//开方函数运算float x = 3;errno = 0;float c = sqrt(x);if (errno == EDOM) printf("输入参数发生错误\n");if (errno == ERANGE)printf("返回值错误\n");if (errno == 0)printf("c=%f\n", c);//运行结果:c=1.732051x = -3;errno = 0;c = sqrt(x);if (errno == EDOM) printf("输入参数发生错误\n"); //运行结果:输入参数发生错误if (errno == ERANGE)printf("返回值错误\n");if (errno == 0)printf("c=%f\n", c);//幂函数运算x = 100;int n = 1000;c = pow(x,n);if (errno == EDOM) printf("输入参数发生错误\n"); if (errno == ERANGE)printf("返回值错误\n");//运行结果:返回值错误if (errno == 0)printf("c=%f\n", c);
//实验float.h中的宏//浮点数加法四舍五入方向printf("FLT_ROUNDS=%d\n", FLT_ROUNDS); //运行结果:FLT_ROUNDS = 1//科学计数法指数部分的底printf("FLT_RADIX=%d\n", FLT_RADIX); //运行结果:FLT_RADIX = 2//浮点类型的最大值printf("FLT_MAX=%f\n", FLT_MAX); //运行结果:FLT_MAX=340282346638528859811704183484516925440.000000printf("DBL_MAX=%f\n", DBL_MAX); //运行结果:略printf("LDBL_MAX=%f\n", LDBL_MAX); //运行结果:略(与上一行相同)//浮点类型最小正值printf("FLT_MIN=%.20f\n", FLT_MIN); //运行结果:FLT_MIN=0.00000000000000000000(保留20位小数看不出来)printf("DBL_MIN=%.20f\n", DBL_MIN); //运行结果:DBL_MIN = 0.00000000000000000000printf("LDBL_MIN=%.20f\n", LDBL_MIN); //运行结果:LDBL_MIN = 0.00000000000000000000//两个同类型浮点住之间可表示的最小差值printf("FLT_EPSILON=%.20f\n", FLT_EPSILON); //运行结果:FLT_EPSILON = 0.00000011920928955078(保留20位小数结果)printf("DBL_EPSILON=%.20f\n", DBL_EPSILON); //运行结果:DBL_EPSILON = 0.00000000000000022204printf("LDBL_EPSILON=%.20f\n", LDBL_EPSILON); //运行结果:LDBL_EPSILON = 0.00000000000000022204//十进制有效位数printf("DECIMAL_DIG=%d\n", DECIMAL_DIG); //运行结果:DECIMAL_DIG=17//浮点运算类型转换遵循printf("FLT_EVAL_METHOD=%d\n", FLT_EVAL_METHOD); //运行结果:FLT_EVAL_METHOD=0//浮点数尾数部分的个数printf("FLT_MANT_DIG=%d\n", FLT_MANT_DIG);//运行结果:FLT_MANT_DIG=24printf("DBL_MANT_DIG=%d\n", DBL_MANT_DIG);//运行结果:DBL_MANT_DIG = 53printf("LDBL_MANT_DIG=%d\n", LDBL_MANT_DIG);//运行结果:LDBL_MANT_DIG = 53//浮点数指数部分有效数字的个数(十进制)printf("FLT_DIG=%d\n", FLT_DIG);//运行结果:FLT_DIG=6printf("DBL_DIG=%d\n", DBL_DIG);//运行结果:DBL_DIG = 15printf("LDBL_DIG=%d\n", LDBL_DIG);//运行结果:LDBL_DIG = 15getchar();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/51945.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

部署 Web 项目到 Linux,可以使他人也访问项目的方法

目录 一、环境配置 二、建构项目并打包 三、上传Jar包到服务器, 并运行 3.1 上传Jar包 3.2 运行 jar 包 3.3 开放端口号 四、其他问题 4.1 运行异常问题 4.2 杀掉进程 五、总结 一、环境配置 如果本地项目是SpringBoot项目&#xff0c;使用的数据库是MySQL&#xff…

ES6 类-总结

我们现在用一段代码&#xff0c; 在注释中总结所有关于JavaScript类的所有用法 class Student extends Person {//这里的Student是子类&#xff0c;Person是父类&#xff0c;extends是实现类之间的继承&#xff0c;它可以自动设置原型university 家里蹲大学; //公共字段(类似…

APP 数据抓取 - Charles 抓包工具的使用(Charles 端口配置、CA 证书配置、Charles Android 模拟器配置)

前言说明 此文章是我在学习 Charles APP 抓包时编写&#xff0c;内容都是亲测有效&#xff0c;文章内容也有参考其他人&#xff0c;参考文章如下&#xff1a; Android 手机使用 charles 抓 https 请求&#xff08;保姆级教程&#xff09;网易 mumu 模拟器安装下载 charles 的…

计算机网络(八股文)

这里写目录标题 计算机网络一、网络分层模型1. TCP/IP四层架构和OSI七层架构⭐️⭐️⭐️⭐️⭐️2. 为什么网络要分层&#xff1f;⭐️⭐️⭐️3. 各层都有那些协议&#xff1f;⭐️⭐️⭐️⭐️ 二、HTTP【重要】1. http状态码&#xff1f;⭐️⭐️⭐️2. 从输入URL到页面展示…

XSLT 实例:掌握 XML 转换的艺术

XSLT 实例&#xff1a;掌握 XML 转换的艺术 引言 XSLT&#xff08;可扩展样式表语言转换&#xff09;是一种强大的工具&#xff0c;用于将 XML&#xff08;可扩展标记语言&#xff09;文档转换为其他格式&#xff0c;如 HTML、PDF 或纯文本。在本文中&#xff0c;我们将通过一…

从Vuex 到 Pinia,Vue 状态管理的进化

Vue.js,一个轻量级且易于上手的 JavaScript 框架,已经在全球范围内获得了广泛的应用。 Vue.js 的状态管理库 Vuex,也为开发者提供了一个统一的状态管理方案。然而,随著 Vue.js 的发展和进化,我们看到了一个新的状态管理库的诞生 — Pinia。在这篇文章中,我们将探讨 Vuex…

2024年9月3日嵌入式学习

数据结构 1定义 一组用来保存一种或者多种特定关系的数据的集合&#xff08;组织和存储数据&#xff09; 程序的设计&#xff1a;将现实中大量而复杂的问题以特定的数据类型和特定的存储结构存储在内存中&#xff0c; 并在此基础上实现某个特定的功能的操作&am…

Springboot集成WebSocket客户端,发送消息并监测心跳

jar包&#xff08;主要jar包&#xff09; <dependency><groupId>org.java-websocket</groupId><artifactId>Java-WebSocket</artifactId><version>1.5.7</version></dependency>服务类 import cn.hutool.json.JSONUtil; impor…

「Python程序设计」条件控制:if-elif-else语句

我们在进行程序设计的过程中&#xff0c;基本上遵循的过程是&#xff0c;找出变量和常量&#xff0c;通过python编程语言&#xff0c;设置变量和常量&#xff0c;以及考虑是否需要赋予初始值。 设计变量和常量&#xff0c;其实就是为了模拟和计算我们的现实世界中&#xff0c;…

学习笔记--Docker

安装 1.卸载旧版 首先如果系统中已经存在旧的Docker&#xff0c;则先卸载&#xff1a; yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine 2.配置Docker的yum库 首先要安…

深入理解 JavaScript DOM 操作

一、DOM 操作分类 &#xff08;一&#xff09;元素查找 根据 ID 值查找&#xff1a;getElementById()&#xff0c;返回符合条件的第一个对象。 var aa document.getElementById("aa");console.log(aa);根据类名查找&#xff1a;getElementsByClassName()&#xff…

IntelliJ IDEA 自定义字体大小

常用编程软件自定义字体大全首页 文章目录 前言具体操作1. 打开设置对话框2. 设置编辑器字体3. 设置编译软件整体字体 前言 IntelliJ IDEA 自定义字体大小&#xff0c;统一设置为 JetBrains Mono 具体操作 【File】>【Settings...】>【Editor】>【Font】 统一设置…

C++:list篇

前言: 观看C的list前需要对链表有一些了解&#xff0c;如C语言的链表结构。本片仅介绍list容器中常用的接口函数概念以及使用。 list的概念&#xff1a; 简而言之&#xff0c;C的list是一个双向带哨兵位的链表容器模板 list的构造&#xff1a; 1.list():默认构造 2.li…

spring之异常和测试相关注解

原文地址 ControllerAdvice和ExceptionHandler 通常组合使用&#xff0c;用于处理全局异常&#xff0c;示例代码如下&#xff1a; ControllerAdvice Configuration Slf4j public class GlobalExceptionConfig {private static final Integer GLOBAL_ERROR_CODE 500;Excepti…

认识git和git的基本使用,本地仓库,远程仓库和克隆远程仓库

本地仓库 #安装git https://git-scm.com/download/win #git是什么&#xff1f;有什么用&#xff1f; git相当于一个版本控制系统&#xff0c;版本控制是一种记录一个或若干文件内容变化&#xff0c;以便将来查阅特定版本修订情况的系统。 作用: 记录&#xff08;项目&#…

[Qt5] 使用QtConcurrent::run在异步线程中执行耗时函数

&#x1f4e2;博客主页&#xff1a;https://loewen.blog.csdn.net&#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;本文由 丶布布原创&#xff0c;首发于 CSDN&#xff0c;转载注明出处&#x1f649;&#x1f4e2;现…

Java-树形图工具类TreeUtil

TreeUtil 工具类,包括列表转树形结构、遍历、查找和删除节点等功能。 import java.util.*;public class TreeUtil {/*** 将列表转换为树形结构。** @param target 扁平化的节点列表* @param getId 获取节点ID的函数* @param getParentId 获取节点父ID的函数* @…

物联网(IoT)支持的小型水处理厂实时硬件在环(HIL)仿真

这篇论文的标题是《Real-Time Hardware-In-The-Loop Simulation of IoT-Enabled Mini Water Treatment Plant》&#xff0c;作者是 Mohamad Taib Miskon 等人&#xff0c;发表在 2024 年 IEEE 自动控制与智能系统国际会议&#xff08;I2CACIS&#xff09;上。以下是该论文的主要…

【Agent】Agent Q: Advanced Reasoning and Learning for Autonomous AI Agents

1、问题背景 传统的训练Agent方法是在静态数据集上进行监督预训练&#xff0c;这种方式对于要求Agent能够自主的在动态环境中可进行复杂决策的能力存在不足。例如&#xff0c;要求Agent在web导航等动态设置中执行复杂决策。 现有的方式是用高质量数据进行微调来增强Agent在动…

学习日志29

论文阅读&#xff1a;IBM Q Experience as a versatile experimental testbed for simulating open quantum systems 引言部分&#xff1a; 引言部分首先介绍了开放量子系统的理论研究的重要性&#xff0c;这些理论描述了量子系统与其环境相互作用的动力学。这种理论对于理解量…