c语言数据类型的转换

本文介绍了C语言中数据类型的转换规则,包括自动转换和强制转换。在运算时,低类型会转换为高类型,例如int转float。同时,详细阐述了不同类型之间的转换顺序,如char、short到int再到unsigned int等。特别指出,float和float相乘结果提升为double类型以防止精度损失。此外,还提到了不同编译器环境下,各种数据类型的字节数可能存在的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.C语言的类性转换规则,自动转换时是低类型向高类型转换,而强制转换也可以将高类型转换为低类型,但可能造成信息丢失。
但是占用相同字节数的数据类型也有高低之分,比如long和unsigned long都占4个字节,但是表达式中同时有long和unsigned long时,先把long转换为unsigned long,然后再参与运算。例如int*float,则将int转换为float,最后的结果为float型
2.char和short → int → unsigned int → long → unsigned long → float → double → long double 
注意:表达式中的float型变量不会自动转换为double型!!!这一条规则在C89中就已明确。但是很多教材采用了传统C的说法——“float将自动转换为double,然后再参与运算”,这对于理解C语言没有本质的不同,但是却是错误的。
3.c语言中float和float型相乘得什么类型?
为避免丢失精度,结果类型提升为double类型。其中的运算包括所有数学运算,即加减乘除。
如两个很大的float数相乘,或两个绝对值很小的float数相乘,前者可能导致溢出,而后者则可能出现数值过小超出float表示范围。
4.不同数据类型的字节数,随编译器不同而不同。
16位编译器:                char :1个字节
char*(即指针变量): 2个字节
short int : 2个字节
int:  2个字节
unsigned int : 2个字节
float:  4个字节
double:   8个字节
long:   4个字节
long long:  8个字节
unsigned long:  4个字节

32位编译器:    char :1个字节
char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)
short int : 2个字节
int:  4个字节
unsigned int : 4个字节
float:  4个字节
double:   8个字节
long:   4个字节
long long:  8个字节
unsigned long:  4个字节
64位编译器: char :1个字节
char*(即指针变量): 8个字节
short int : 2个字节
int:  4个字节
unsigned int : 4个字节
float:  4个字节
double:   8个字节
long:   8个字节
long long:  8个字节
unsigned long:  8个字节
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值