C语言自动转换类型

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言自动转换类型相关的知识,希望对你有一定的参考价值。

①printf("%d",3.5);
②printf("%f",5);
为什么不会自动转换类型 那什么时候才会自动转换类型

带有不定参数列表得函数不进行类型转换,因为再分析printf参数时,编译器不知道类型到底该是什么。%d/%f都是运行时信息,编译器是不分析得。

只要编译器知道目标类型是什么它,都尝试做类型转换追问

那什么时候他知道目标类型 举下例子 我就知道y=3+3.0 这种情况

追答

y得类型是已知的,编译器当然知道=右侧得必须转换为y得类型
常见得情况是:
1。变量赋值
2。函数传参数(不定参数列表是特例,因为它不知道参数类型)

参考技术A 类型相容时,例如:
double a=1.0;
a+=1;
int b=12;
char c=3;
b+=c;
函数调用也一样,但是有多种可能时必须强制转换。例如:
sqrt(12)在VC2010下是不行的。必须要sqrt((double)12)或者sqrt((long double)12)。
但是printf函数原型是int printf(const char *format,...);它没有指明后面参数的类型,故不发生隐式转换。
参考技术B 这是语法 参考技术C 不懂。

C语言中的数据类型转换

文章目录


变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,一种是强制转换。
1) 自动转换:在不同类型数据的混合运算中,由系统自动实现转换,由少字节类型向多字节类型转换。不同类型的量相互赋值时也由系统自动进行转换,把赋值号右边的类型转换为左边的类型。
2) 强制转换:由强制转换运算符完成转换

1 自动转换

自动转换发生在不同数据类型的变量混合运算时,由编译系统自动完成。类型自动转换的规则如下:

1)若参与运算量的类型不同,则先转换成同一类型,然后进行运算;
2) 转换按数据长度增加的方向进行,以保证精度不降低。如 int 型和 long 型运算时,先把 int 量转成 long
型后再进行运算。
3) 所有的浮点运算都是以双精度进行的,即使仅含 float 单精度量运算的表达式,也要先转换成 double
型,再作运算。
4) char 型和 short 型参与运算时,必须先转换成 int 型。
5) 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。

2 强制类型转换

强制类型转换是通过类型转换运算来实现的。
其一般形式为:(类型说明符) (表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。
在使用强制转换时应注意以下问题:
1) 类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y 则成了把 x转换成 int 型之后再与 y 相加了。
2) 无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。

以上是关于C语言自动转换类型的主要内容,如果未能解决你的问题,请参考以下文章

C语言数据类型的转换

C语言,自动类型转换怎么做?

C语言举例说明啥情况下会发生自动类型转换

C语言类型的自动转换时,啥类型能转换成啥类型呀?、嘿嘿,比如类型和decimal类型混合在一个表达

关于C语言数据类型转换的一个小问题,很简单哦!!

在c语言中数据类型转换主要有哪几种方式