自动类型转换
计算机术语
自动类型转换是一个计算机术语,若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
转换规则
在C语言中,自动类型转换遵循以下规则:
1、若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2、转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
a、若两种类型的字节数不同,转换成字节数高的类型
b、若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型
3、所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4、char型和short型参与运算时,必须先转换成int型。
5、在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
隐式转换
C++语言
编译系统
提供的内部
数据类型
的隐式自动转换规则如下:
1、执行算术运算时,低类型(短字节)可以转换为高类型(长字节);例如: int型转换成double型,char型转换成int型等等;
2、
赋值表达式
中,等号右边表达式的值的类型自动隐式地转换为左边
变量
的类型,并赋值给它;
3、
函数调用
时,将
实参
的值传递给
形参
,系统首先会自动隐式地把实参的值的类型转换为形参的类型,然后再赋值给形参;
4、函数有返回值时,系统首先会自动隐式地将返回
表达式
的值的类型转换为函数的返回类型,然后再赋值给调用函数返回;
参考资料
最新修订时间:2024-05-27 15:21
条目作者
小编
资深百科编辑
目录
概述
转换规则
参考资料
Copyright©2024
闽ICP备2024072939号-1