【C语言】深入理解C语言中的数学运算和类型转换

文章目录

  • 引言
  • 取负运算的奥秘
    • 源码探索
    • 分析与解读
  • 浮点数运算的精细差异
    • 源码分析
  • 精度损失与隐式类型转换
  • 精度和除零运算探究
    • float类型和double类型的精度各是多少(即十进制有效位的位数)?
    • 在你的机器上,“负数开方”是如何处理的(如“-8.0/0”、“sqrt(-4.0)”的运算结果)?
    • 在你的机器上,整数除0和浮点数除0的运行结果各是什么?为什么会有不同的运行结果?,并将“-6.0/0”和“-6/0”的运行结果进行比较。
  • 结语

引言

在编程中,理解各种数据类型的运算规则是至关重要的。本文将通过几个示例,深入探讨C语言中整数和浮点数的取负运算、浮点数的精度问题以及除零运算的处理机制。

取负运算的奥秘

源码探索

分析以下简单的C程序:

int main()
{int x = -2147483648;int y = 3;float f = 1.5;printf("%d\n", -x > y);printf("%f\n", -f);return 0;
}

在这里插入图片描述
在这里插入图片描述

分析与解读

  • 当我们对整数 x 取负时,由于它已经是32位整数的最小可能值,其补码表示无法再表示一个更大的正数,因此 -x 仍然等于 -2147483648。这导致 -x > y 的判断为,因此第一个 printf 输出为0

  • 另一方面,浮点数 f 的取负运算简单明了,结果自然就是 -1.5。因此,第二个 printf 输出 -1.500000

浮点数运算的精细差异

源码分析

接下来,我们看一个涉及浮点数运算的程序:

#include <stdio.h>
int main()
{float x = -1.5e38;float y = 1.5e38;float z = 1.0;int i = (x + y) + z;int j = x + (y + z);printf("%d\n", i == j);return 0;
}

在这里插入图片描述
在这里插入图片描述

精度损失与隐式类型转换

  • 在上述代码中,我们试图通过不同的运算顺序来比较结果是否相同。然而,由于浮点数的精度限制和整数类型的截断行为ij 得到的结果很可能不同,因此输出为0(false)。这个例子清晰地展示了浮点数运算中的精度损失和隐式类型转换可能导致的意外结果。

  • 在表达式 (x + y) + z 中,xy 是浮点数,而 z 是浮点数转换为整数后的结果。根据C语言的运算规则,当一个浮点数和一个整数进行运算时,整数会被自动转换为浮点数。因此,(x + y) 的结果是一个浮点数,再加上 z 后得到的结果也是一个浮点数。然而,由于 i 是整型变量,这个浮点数会被截断成整数并赋值给 i
    类似地,在表达式 x + (y + z) 中,yz 是浮点数,而 x 是一个负浮点数。同样根据C语言的运算规则,负浮点数和浮点数进行运算时,会进行隐式类型转换,使结果仍为浮点数。因此,(y + z) 的结果是一个浮点数,再加上 x 后得到的结果也是一个浮点数。然而,由于 j 是整型变量,这个浮点数会被截断成整数并赋值给 j

  • 如果想要避免隐式类型转换,可以显式地进行类型转换操作,将浮点数转换为整型。例如,可以使用 int(i)int(j) 来将浮点数转换为整型。这样可以确保进行精确的整数比较

精度和除零运算探究

float类型和double类型的精度各是多少(即十进制有效位的位数)?

#include <stdio.h>
#include <float.h>int main() {printf("float类型的十进制有效位数: %d\n", FLT_DIG);printf("double类型的十进制有效位数: %d\n", DBL_DIG);return 0;
}

在这里插入图片描述
在C语言中,可以使用float.h头文件中定义的常量来获取floatdouble类型的精度信息。具体而言,FLT_DIG和DBL_DIG分别表示floatdouble类型的十进制有效位数。
这段代码将打印出floatdouble类型的十进制有效位数。在大多数系统上,你会看到类似以下的输出:
float类型的十进制有效位数: 6
double类型的十进制有效位数: 15
这样就直接获取了floatdouble类型的十进制有效位数,而无需手动计算。

在你的机器上,“负数开方”是如何处理的(如“-8.0/0”、“sqrt(-4.0)”的运算结果)?

在这里插入图片描述

  • 当进行表达式 -8.0/0 进行计算时,结果会被认为是负无穷大(-∞)。这是因为除以零是一个非法的操作,C语言规定将其视为一种特殊情况,结果被定义为负无穷大或正无穷大。
    在这里插入图片描述
  • 当进行表达式 sqrt(-4.0) 进行计算时,结果会被认为是一个特殊值NaN(Not a Number),表示无效的操作。负数的平方根是一个虚数,在实数域中没有定义。

在你的机器上,整数除0和浮点数除0的运行结果各是什么?为什么会有不同的运行结果?,并将“-6.0/0”和“-6/0”的运行结果进行比较。

在这里插入图片描述

在VS中,错误C2124表示发生了除以零或求模运算中的被零除的情况。这个错误通常出现在编译时,是因为代码中存在了除以零或对零求模的操作,这是一种不合法的操作。
这个错误会阻止程序的继续编译,因为除以零是一种未定义的行为,违反了数学和计算机的基本规则。
要解决这个错误,你需要检查代码中是否存在除以零或对零求模的操作,并确保避免这种情况的发生。可以通过添加适当的条件判断来避免除以零或对零求模,在进行除法或求模运算之前检查除数是否为零。
例如,可以使用条件语句来避免除以零的情况:

if(b != 0) {result = a / b; // 在除数不为零时执行除法运算
} 
else{// 处理除数为零的情况,例如输出错误信息或采取其他操作printf("除数不能为零\n");
}

结语

通过本文的分析,我们了解了C语言中数学运算和类型转换的一些关键细节。从取负运算到浮点数的精度,再到除零的处理,每个概念都对编写可靠和高效的代码至关重要。希望这篇文章能帮助你在未来的编程实践中避免一些常见的陷阱。

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

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

相关文章

【Spring Boot】如何集成mybatis-plus

在pom文件中导入maven坐标 <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.23</version></dependency><!--mybatis-plus--><dependency><groupId>com.ba…

uniapp 连接斑马PDA调试

1、先把PDA设置成开发者模式 打开设置--》关于手机 --》单击版本号&#xff0c;5次以上 连线单击5次以上 2、后退--》找到系统 --》高级 3、打开 --》开发都模式 4、找到调试 --》 打开USB调试 5、设置USB偏好设置&#xff0c;插入电脑连接PDA就会在通知栏上显示&#xff0c;默…

蓝桥杯 动态规划

01 数字三角形 #include<bits/stdc.h> using namespace std; const int N105; using lllong long; ll a[N][N],dp[N][N]; int main(){int n;cin>>n;for(int i1;i<n;i){for(int j1;j<i;j){cin>>a[i][j];}}for(int i5;i>1;i--){for(int j1;j<i;j){…

拒绝废话,直接开画!Python零基础教程之画图

引文 很多教程&#xff0c;开始教python&#xff0c;就是语法呀&#xff0c;字符类型这些基础的&#xff0c;虽说是基础&#xff0c;你也不能说没用。 但是&#xff0c;对于前期要快速成长的我们来说&#xff0c;属实不够看。 我们是新手&#xff0c;我们是菜鸟&#xff0c;但…

OTFX欧汇提供更优质的外汇交易产品和服务

OTFX的外汇交易明智决策能力&#xff1a;准确捕捉外汇市场机会&#xff0c;实现稳定盈利 把握机遇&#xff0c;重要的是争取而不是等待。在金融市场中&#xff0c;明智的决策能力对于外汇交易成败至关重要。及时的断绝&#xff0c;果断的出手&#xff0c;才能够保证出手的成功…

提升Jmeter测试效率的9种参数化方法!

jmeter工具无论做接口测试还是性能测试&#xff0c;参数化都是一个必须掌握且非常有用的知识点。参数化的使用场景: 1&#xff09;多个请求都是同一个ip地址&#xff0c;若服务器地址更换了&#xff0c;则脚本需要更改每个请求的ip 2&#xff09;注册账号&#xff0c;不允许账…

力扣572:另一棵树的子树

力扣572&#xff1a;另一棵树的子树 给你两棵二叉树 root 和 subRoot 。检验 root 中是否包含和 subRoot 具有相同结构和节点值的子树。如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 二叉树 tree 的一棵子树包括 tree 的某个节点和这个节点的所…

用友NC FileUploadServlet 反序列化RCE漏洞复现

0x01 产品简介 用友 NC 是用友网络科技股份有限公司开发的一款大型企业数字化平台。 0x02 漏洞概述 用友 NC nc.file.pub.imple.FileUploadServlet 反序列化漏洞,攻击者可通过该漏洞在服务器端任意执行代码,写入后门,获取服务器权限,进而控制整个web服务器。 0x03 复现环…

龙迅LT2611UX 四端口LVDS转HDMI(2.0)

1.描述&#xff1a; LT2611UX 四端口LVDS TO HDMI2.0。 LT2611UX是一款高性能得LVDS到HDMI2.0转换器得STB&#xff0c;DVD应用程序&#xff0c;LVDS输入可以配置单端口&#xff0c;双端口或者四端口&#xff0c;带有一个高速时钟通道&#xff0c;最多可运行三到四个高速数据…

第一节JavaScript 简介与使用

JavaScript简介 JavaScript是互联网上最流行的脚本语言&#xff0c;这门语言可用于HTML和Web&#xff0c;更广泛用于服务器、PC、电脑、智能手机等设备上。 JavaScript是一种轻量级的编程语言。 JavaScript是可插入HTML页面的编程代码。 JavaScript插入HTML页面后&#xff…

算法基础六

搜索插入位置 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2 示例 2: 输入: nums [1,3,5,6], target 2 输…

Linux常用快捷键

1. tab 键补全 1)当我们忘记了一些指令怎么写时&#xff0c;可以双击tab键&#xff0c;查看所有指令&#xff0c;显示出来后可以按enter键往下翻&#xff0c;想要取消命令可以按ctrl c。 2)知道开头怎么写&#xff0c;后面的忘了&#xff0c;也可以双击tab键查询开头排列的指令…

通过证书透明度发现更多相关资产

通过证书透明度发现更多相关资产 1.证书透明度概述2.搜索实战3.为什么证书透明度技术是可行的4.DigiCert 和其他 CA5.缺陷缓解措施 1.证书透明度概述 许多现代网站都采用自动颁发和续订 TLS 证书&#xff0c;在设置 TLS 证书部署的方式上存在缺陷。它允许任何人发现同一服务器…

【皇帝的新装】像管理产品一样,来管理自己

在前进的路上需要不时的回头看&#xff0c;看自己来时的脚步&#xff0c;是杂乱无章&#xff0c;还是方向一致。善于从经验中总结可以让我们少走许多弯路&#xff0c;降低我们的消耗。 偶然间&#xff0c;回头看看&#xff0c;入行产品经理已经三年有余。沉迷在各种具体事务中&…

回溯法及例题(C++实现)

回溯法概念 概念&#xff1a;在包含问题所有解的解空间树中&#xff0c;按照深度优先搜索的策略&#xff0c;根据根结点&#xff08;开始节点&#xff09;出发搜索解空间树。 流程&#xff1a;首先根结点成为活节点&#xff0c;同时也成为当前的扩展结点。在当前的扩展结点处…

代码随想录day5 哈希表part 01 242.有效的字母异位词 349. 两个数组的交集 202. 快乐数 1. 两数之和

当我们遇到了要快速判断一个元素是否出现集合里的时候&#xff0c;就要考虑哈希法。 哈希碰撞&#xff1a;1、拉链法&#xff1a;其实拉链法就是要选择适当的哈希表的大小&#xff0c;这样既不会因为数组空值而浪费大量内存&#xff0c;也不会因为链表太长而在查找上浪费太多时…

<JavaEE> 单例模式的两种实现:“饿汉模式”和“懒汉模式”

目录 一、单例模式概述 二、“饿汉模式”实现单例模式 三、“懒汉模式”实现单例模式 3.1 单线程下的“懒汉模式” 3.2 多线程下的“懒汉模式” 一、单例模式概述 1&#xff09;什么是单例模式&#xff1f; 单例模式是一种设计模式。 单例模式可以保证某个类在程序中只存…

免费百度SEO优化工具,百度SEO优化排名工具

百度SEO关键词工具 让我们聚焦在百度SEO关键词工具上。对于任何想要在百度搜索引擎中脱颖而出的网站管理员而言&#xff0c;深入了解用户搜索习惯和关键词的选择是至关重要的。 百度SEO关键词工具不仅提供了免费的服务&#xff0c;而且功能强大。通过输入相关领域的关键词&…

ESP32-Web-Server编程-通过 Web 下载文本

ESP32-Web-Server编程-通过 Web 下载文本 概述 当你希望通过网页导出设备的数据时&#xff0c;可以在 ESP32 上部署一个简单的文件 Web 服务器。 需求及功能解析 本节演示如何在 ESP32 上部署一个最简单的 Web 服务器&#xff0c;来接收浏览器或者 wget 指令请求文件数据。…

VMware安装Ubuntu系统(Server端,Desktop端步骤一样)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…