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

相关文章

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

C语言进阶(预处理命令详解)

《C语言进阶(预处理命令详解)》文章讲解了宏定义规范、头文件包含方式及条件编译应用,强调带参宏需加括号避免计算错误,头文件应声明函数原型以便主函数调用,条件编译通过宏定义控制代码编译,适用于测试与模块... 目录1.宏定义1.1不带参宏1.2带参宏2.头文件的包含2.1头文件中的内容2.2工程结构3.条件编

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont