astype强制转换不管用_C语言别再随意用double了

本文详细介绍了编程中的数据类型转换,包括自动转换和强制转换。自动转换遵循“按数据长度增加的方向”原则,确保精度不降低。所有浮点运算都是以双精度进行,char和short参与运算时转为int。有符号和无符号整型混合运算时,有符号转为无符号。强制转换通过类型转换运算实现,需要注意括号的使用。转换仅在运算期间临时,不影响变量原始类型。
摘要由CSDN通过智能技术生成

首先变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,另一种是强制转换。

自动转换即当不同类型的数据进行混合运算时,编译系统将按照一定的规则自动完成。

而强制类型转换是由程序员通过编程强制转换数据的类型。

自动转换的规则如下:

83b4cf0fa3d53ff26a4c1197b92d3dc6.png
6fdd8545ebb43b77b3dafbb7662f0086.png

1) 当参与运算的数据的类型不同时,编译系统会自动先将它们转换成同一类型,然后再进行运算。

但问题是转换的时候是谁转换成谁呢?转换的基本规则是“按数据长度增加的方向进行转换”,以保证精度不降低。比如 int 型数据和 long 型数据进行相加或相减运算时,系统会先将 int 型数据转换成 long 型,然后再进行运算。这样的话运算结果的精度就不会降低。

long 是“大水桶”,int 是“小水桶”。int 能存放的,long 肯定能存放;而 long 能存放的,int 不一定能存放。

2) 所有的浮点运算都是以双精度进行的。

在运算时,程序中所有的 float 型数据全部都会先转换成 double 型。即使只有一个 float 型数据,也会先转换成 double 型,然后再进行运算。为什么要这样呢?因为 CPU 在运算的时候有“字节对齐”的要求,这样运算的速度是最快的。这个现在先不管,如果以后有机会学习汇编的话你就知道原因了。

3) char 型和 short 型数据参与运算时,必须先转换成 int 型。这也是涉及 CPU 的运行原理的,记住就行了。

4) 有符号整型和无符号整型混合运算时,有符号型要转换成无符号型,运算的结果是无符号的。这条规则经常使人纠结,可以写一个程序看一下。

# include

int main(void)

int a = -10;

unsigned b = 5;

if ((a+b) > 0)

printf("Hello");

return 0;

答案:输出Hello

思考:对于a+b来说,计算结果如果使用%d格式进行打印,则会输出-5;若以%u形式打印,则会输出一个很大的正整数。思考这是为什么。

强制类型转换是通过类型转换运算来实现的。其一般形式为: (类型说明符) (表达式) 其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。

例如: (float) a 把a转换为浮点型,(int)(x+y) 把x+y的结果转换为整型。在使用强制转换时应注意以下问题:

1.类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。

2.无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。

例:

int main

float f=5.75;

printf("f=%d,f=%f

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值