c语言数据类型转换的方法


本文摘自PHP中文网,作者藏色散人,侵删。

c语言数据类型转换的方法

数据类型转换就是将数据(变量、数值、表达式的结果等)从一种类型转换为另一种类型。

自动类型转换

自动类型转换就是编译器默默地、隐式地、偷偷地进行的数据类型转换,这种转换不需要程序员干预,会自动发生。

1) 将一种类型的数据赋值给另外一种类型的变量时就会发生自动类型转换,例如:

1

float f = 100;

100 是 int 类型的数据,需要先转换为 float 类型才能赋值给变量 f。再如:

1

int n = f;

f 是 float 类型的数据,需要先转换为 int 类型才能赋值给变量 n。

在赋值运算中,赋值号两边的数据类型不同时,需要把右边表达式的类型转换为左边变量的类型,这可能会导致数据失真,或者精度降低;所以说,自动类型转换并不一定是安全的。对于不安全的类型转换,编译器一般会给出警告。

2) 在不同类型的混合运算中,编译器也会自动地转换数据类型,将参与运算的所有数据先转换为同一种类型,然后再进行计算。转换的规则如下:

转换按数据长度增加的方向进行,以保证数值不失真,或者精度不降低。例如,int 和 long 参与运算时,先把 int 类型的数据转成 long 类型后再进行运算。

所有的浮点运算都是以双精度进行的,即使运算中只有 float 类型,也要先转换为 double 类型,才能进行运算。

char 和 short 参与运算时,必须先转换成 int 类型。

下图对这种转换规则进行了更加形象地描述:

unsigned 也即 unsigned int,此时可以省略 int,只写 unsigned。

自动类型转换示例:

1

2

3

4

5

6

7

8

9

10

#include<stdio.h>

int main(){

    float PI = 3.14159;

    int s1, r = 5;

    double s2;

    s1 = r * r * PI;

    s2 = r * r * PI;

    printf("s1=%d, s2=%f\n", s1, s2);

    return 0;

}

运行结果:

1

s1=78, s2=78.539749

在计算表达式r*r*PI时,r 和 PI 都被转换成 double 类型,表达式的结果也是 double 类型。但由于 s1 为整型,所以赋值运算的结果仍为整型,舍去了小数部分,导致数据失真。

更多编程相关内容,请关注php中文网编程入门栏目!

以上就是c语言数据类型转换的方法的详细内容!

相关阅读 >>

0基础学C语言看什么书?

C语言用什么函数来比较字符串大小?

C语言用户标识符命名规则是什么?

C语言如何输出玫瑰花数?(代码示例)

C语言如何求两个数的最大公约数

新手学习C语言必须要知道的特点

C语言自定义函数

C语言中的三目运算符是什么

C语言中合法标识符有哪些

精通C语言能做什么

更多相关阅读请进入《C语言》频道 >>



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...