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

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

自动类型转换

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

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

float f = 100;

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

int n = f;

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

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

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

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

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

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

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

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

自动类型转换示例:

#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;}

运行结果:

s1=78, s2=78.539749

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

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

更多相关文章

  1. c语言中形参的默认存储类型是什么?
  2. c语言函数返回值类型由什么决定?
  3. c语言给数组赋值的3种形式
  4. c语言规定,函数返回值的类型是由什么决定的?
  5. c语言函数类型有几种
  6. c语言double类型默认输出几位小数?
  7. c语言的四大数据类型是什么?
  8. c语言数组的定义及赋值
  9. c++中main函数的返回值类型是什么

随机推荐

  1. mysql 服务意外停止1067错误解决办法小结
  2. 如何在PhpMyAdmin中列出/查看存储过程
  3. ASP.NET GridView 绑定 MySql数据库
  4. MYSQL学习笔记2之MySQL 管理
  5. vmware12下的centos7 linux 安装 mysql5.
  6. MySQL开启远程链接(2014.12.12)
  7. 如何使用mysql在php文件夹中快速更改图像
  8. 为什么这个查询需要很长时间才能执行
  9. mysql进阶(十一)外键在数据库中的作用
  10. 如何启用对MySQL服务器的外部访问?