C语言从头学18——类型的自动转换

2024-06-10 21:12

本文主要是介绍C语言从头学18——类型的自动转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        某些情况下,C语言会自动转换某个值的类型,以下几种情况有必要了解:
   1、赋值运算过程中类型转换
        赋值运算符会自动将右边的值转成左边变量的类型。
        (1) 浮点数赋值给整数变量,C语言会直接丢弃小数部分,而不是四舍五入。如:
              int x=1.99; //x的值是1而不是2
             这种丢弃对于程序运行中数据的精度有影响,编程过程中必须考虑到。
        (2) 整数赋值给浮点数变量,会自动转变成浮点数,这种转变对精度没有影响。
        (3) 窄类型赋值给宽类型,所谓窄类型即是所占字节数较少的类型,反之就是宽类型。这种转换对程序运算精度没有影响。如:
              char a=127;// char类型占1个字节( 类型占字节数用sizeof()可获得 )
              int x=a; // int类型占4个字节
         (4) 宽类型赋值给窄类型,会发生截值(truncation)现象,还是拿 int 转 char 举例,int占4个字节 char 占一个字节,如把一个 int 类型的值赋给 char 类型变量,int 类型4个字节的值只能将最后一个字节的值传给 char,其余3个字节的值都扔掉了。为了保证精度,这种情况应当尽量避免。但有时我们也反其道而用之,比如需要取整时,我们把float类型值或变量赋给 int 类型变量,就可以达到取整的目的。
   2、混合类型运算中的类型转换
       不同类型的值进行计算时,必须先转成同一个类型才能进行计算。
       (1) 整数与浮点数混合运算时,整数先转为浮点数类型再与另一个运算数运算。如:int 会转成
float或double。
       (2) 不同的浮点数类型混合运算时,宽度较小的类型先转为宽度较大的类型再进行运算,如float 会转成 double。
       (3) 不同的整数类型混合运算时,宽度较小的类型会提升为宽度较大的类型,如short会转为 int。
       在做混合运算时,应避免无符号数与有符号数的混合运算。因为这时C语言会自动将有符号数转为无符号数,这种转变可能会超出预期。当然这种情况也极为少见。
      事实上,上述类型的自动转换在我们编程过程中应当尽量避免,因为可能发生不可预见的结果。但有时类型的转换又是必须进行的,下一篇文章将介绍"类型的显示转换"。
     写一个简单的例子对上面的介绍再做进一步的说明:

#include<stdio.h>
int main(void)
{//浮点数赋值给整型float PI = 3.14159, r = 1;int S = r * r * PI; //小数部分被舍去(等号右边先计算出结果后再舍小数)printf("S=%d\n", S); //运行结果:S=3 
//整数赋值给浮点数int a1 = 3;float b1 = a1;//不影响精度printf("float b1=%f\n", b1);//运行结果:float b1=3.000000 
//窄类型赋值给宽类型short a2 = 32767;long b2 = a2;//不影响精度printf("long b2=%d\n", b2); //运行结果:long b2=32767 
//宽类型赋值给窄类型double x1 = 1234567890.123456;float y1=x1; //小数部分和整数部分都有变化,发生错误printf("y1=%f\n", y1); //运行结果:y1=1234567936.000000 
//整数与浮点数混合运算float x2 = 3.14;int a3 = 2; float y3 = a3 * x2; //a3自动转为floatprintf("y3=%f\n", y3); //运行结果:y3=6.280000
//不同宽度浮点类型混合运算float x3 = 0.511; double x4 = 0.722111;double y4 = x3 + x4;//x3自动转成doubleprintf("y4=%f\n", y4); //运行结果:y4=1.233111getchar(); //阻塞程序运行return 0;
}


 

这篇关于C语言从头学18——类型的自动转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十