C语言表达式求值、隐式类型转换、算数转换

2024-04-21 22:12

本文主要是介绍C语言表达式求值、隐式类型转换、算数转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、表达式求值
  • 二、隐式类型转换
      • 小案例
  • 三、算数转换
  • 总结


前言

  • C语言表达式求值、隐式类型转换、算数转换等介绍

一、表达式求值

  • 表达式求值的顺序一部分是由操作符的优先级结合性决定的。
  1. 表达式求值由操作符优先级决定
    • 优先级讨论的是相邻操作符
#include <stdio.h>
int main()
{int a = 3 + 5 / 6;// 此处表达式的值由操作符的优先级决定// 除号 的优先级高于 加号, 同时加号的优先级高于 赋值。// 因此他的执行顺序为: 5 / 6 ----->  3 + 0 ------> a = 3// 表达式的结果为3printf("%d", a); // 3return 0;
}
  1. 表达式求值由操作符结合性决定
  • 操作符的优先级相同时,按照操作符的结合性决定执行顺序
#include <stdio.h>
int main()
{int a = 3 + 5 + 3;// 此时,优先级相同,加号 的结合性时从左向右// 所以此时程序的执行顺序为 3 + 5 ----> 8 + 3 结果为11printf("%d", a);return 0;
}

同样,有些表达式的操作数在求值过程中可能需要转换为其他类型。

二、隐式类型转换

  • C的整型算数运算总是至少以缺省整型类型的精度来进行。
  • 为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换成为整型提升。
  • 整型提升的意义:
  • 表达式的整型运算要在CPU的相应运算器件内执行,CPU内整型运算器(ALU)的操作数的字节长度一般就是 int 的字节长度, 同时也是CPU的通用寄存器长度。
  • 因此,即使两个 char 类型相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长度。
  • 通用CPU是难以直接实现两个8比特字节直接相加运算(虽然机器指令中可能由这种字节相加指令)。所以,表达式中各种长度可能小于int长度的整型值,都必须先转换为 int 或 unsigned int ,然后才能送入CPU去执行计算。
    整型提升是按照变量的数据类型的符号位来提升的
    无符号整型提升,高位补零
    有符号整型提升,高位补符号位,负数则反码补 1,正数则反码补0
#include <stdio.h>
int main()
{char a = 5;char b = 126;// 字符在内存中存储的是ASCII值,本质上属于整型运算// 要在CPU的运算器内运算, 小于 int 类型的必须先转换为 int 类型在进行运算// 5 的二进制 00000000000000000000000000000101// char a 的二进制,他只有 1 个字节,8 个比特位// 00000101 ----- a// //126 的二进制 00000000000000000000000001111110// char b 的二进制// 01111110 ---- b//// 参与运算时,不足整型精度的要进行整型提升//// a 转换位 int 类型,进行整型提升 // char 为有符号类型,所以整型提升是,高位补符号位,即补0// 00000000000000000000000000000101//// 整型提升转换为int,高位补0// 00000000000000000000000001111110// 相加// 00000000000000000000000010000011// char c 只能放8个比特位// 10000011 ----- c// 打印整型时,进行整型提升,符号位为 1,高位补1// 11111111111111111111111110000011 ---- 补码// 11111111111111111111111110000010 ---- 反码// 10000000000000000000000001111101 ---- 原码 -----> -125char c = a + b;printf("%d", c); // -125return 0;
}
  • 字符在内存中存储的是ASCII值,本质上属于整型运算
  • 要在CPU的运算器内运算, 小于 int 类型的必须先转换为 int 类型在进行运算

小案例

int main()
{char a = 0xb6;short b = 0xb600;int c = 0xb6000000;if (a == 0xb6)printf("a");if (b == 0xb600)printf("b");if (c == 0xb6000000)printf("c"); // c// 程序的结果只打印 c// a == 0xb6 和 b == 0xb600 也是表达式// 在表达式运算时,shor char 类型需要整型提升return 0;
}
  • 整型提升会变为4个字节。
  • 整型提升参与运算,表达式的结果也是4个字节。
#include <stdio.h>
int main()
{char c = 1;printf("%u\n", sizeof(c));// 1printf("%u\n", sizeof(+c)); // 4printf("%u\n", sizeof(-c)); // 4return 0;
}

三、算数转换

  • 如果某个操作符的各个操作数属于不同的类型,那么除非其中一个操作数转换为零一操作数的类型,否则操作就无法进行,下面的层次体系成为寻常算数转换。

long double
double
float
unsigned long int
long int
unsigned int
int

  • 如果某个操作数的类型在上面这个列表中,排名较低,那么首先要转换为另一个操作数的类型后执行运算。
  • 算数转换要合理,否则会有一些潜在问题。
  • 问题表达式 ---- 无法确定唯一的计算路径
    • a * b + c * d + e * f
    • c + --c

总结

C语言表达式求值、隐式类型转换、算数转换以及一些问题表达式等的简单介绍。

这篇关于C语言表达式求值、隐式类型转换、算数转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/924159

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

Python19 lambda表达式

在 Python 中,lambda 表达式是一个小型匿名函数,通常用于实现简单、单行的函数。lambda 函数可以接受任意数量的参数,但只能有一个表达式。 基本语法: lambda arguments: expression 这里,arguments 是传递给 lambda 的参数,expression 是关于这些参数的表达式,它的计算结果就是 lambda 函数的返回值。 使用

LangChain转换链:让数据处理更精准

1. 转换链的概念 在开发AI Agent(智能体)时,我们经常需要对输入数据进行预处理,这样可以更好地利用LLM。LangChain提供了一个强大的工具——转换链(TransformChain),它可以帮我们轻松实现这一任务。 转换链(TransformChain)主要是将 给定的数据 按照某个函数进行转换,再将 转换后的结果 输出给LLM。 所以转换链的核心是:根据业务逻辑编写合适的转换函

java8的新特性之一(Java Lambda表达式)

1:Java8的新特性 Lambda 表达式: 允许以更简洁的方式表示匿名函数(或称为闭包)。可以将Lambda表达式作为参数传递给方法或赋值给函数式接口类型的变量。 Stream API: 提供了一种处理集合数据的流式处理方式,支持函数式编程风格。 允许以声明性方式处理数据集合(如List、Set等)。提供了一系列操作,如map、filter、reduce等,以支持复杂的查询和转

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

人工和AI大语言模型成本对比 ai语音模型

这里既有AI,又有生活大道理,无数渺小的思考填满了一生。 上一专题搭建了一套GMM-HMM系统,来识别连续0123456789的英文语音。 但若不是仅针对数字,而是所有普通词汇,可能达到十几万个词,解码过程将非常复杂,识别结果组合太多,识别结果不会理想。因此只有声学模型是完全不够的,需要引入语言模型来约束识别结果。让“今天天气很好”的概率高于“今天天汽很好”的概率,得到声学模型概率高,又符合表达

C语言 将“China”译成密码

将“China”译成密码,密码规律是:用原来的字母后面的第4个字母代替原来的字母。例如,字母“A”后面的第4个字母是“E”,用“E”代替“A”。因此,“China”应译为“Glmre”。编译程序用付赋初值的方法使c1,c2,c3,c4,c5这五个变量的值分别为“C”,“h”,“i”,“n”,“a”,经过运算,使c1,c2,c3,c4,c5分别变成“G”,“l”,“m”,“r”,“e”。分别用put

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

工程文档CAD转换必备!在 Java 中将 DWG 转换为 JPG

Aspose.CAD 是一个独立的类库,以加强Java应用程序处理和渲染CAD图纸,而不需要AutoCAD或任何其他渲染工作流程。该CAD类库允许将DWG, DWT, DWF, DWFX, IFC, PLT, DGN, OBJ, STL, IGES, CFF2文件、布局和图层高质量地转换为PDF和光栅图像格式。 Aspose API支持流行文件格式处理,并允许将各类文档导出或转换为固定布局文件格

【LinuxC语言】select轮询

文章目录 前言select函数详解selectfd_set类型一个小问题select函数使用步骤改进服务器代码select服务器示例代码 总结 前言 在Linux C语言编程中,我们经常需要处理多个I/O操作。然而,如果我们为每个I/O操作创建一个线程,那么当I/O操作数量增加时,线程管理将变得复杂且效率低下。这就是我们需要select轮询的地方。select是一种高效的I/