基本数据类型转换
1. 自动类型转换
1. 自动类型转换
介绍:当 C 程序在进行赋值或者运算时,精度小的类型自动转换为精度大的数据类型,这个就是自动类型转换。
2. 数据类型按精度(容量)大小排序为
3. 数据类型自动转换表规则
4. 案例演示
- 演示一下基本数据类型转换的基本情况。
#include<stdio.h>
void main(){
char c1 = 'a';
int num1 = c1;//ok
double d1 = num1;//ok
short s1 = 10;
int num2 = 20;
int num3 = s1 + num2;
printf("d1=%f \n",d1);
printf("num3=%d",num3);
getchar();
}
5. 自动类型转换细节说明
-
- 有多种类型的数据混合运算时,系统首先自动将所有数据转换成精度最大的那种数据类型,然后再进行计算(如
int
型和 short
型运算时,先把 short
转成 int
型后再进行运算)。 - 若两种类型的字节数不同,转换成字节数大的类型,若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型
- 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边的类型将转换为左边的类型,如果右边变量的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入
- 代码演示:
#include<stdio.h>
void main(){
float f1 = 1.1f;
double d2 = 4.58667435;
f1 = d2;//出现精度损失(double->float)
printf("f1=%.8f",f1);
getchar();
2. 强制类型转换
1. 强制类型转换
-
- 介绍
将精度高的数据类型转换为精度小的数据类型。使用时要加上强制转换符 ( )
,但可能造成精度降低或溢出,格外要注意。 - 强制类型转换一般格式如下:
(类型名) 表达式
什么是表达式: 任何有值都可以称为表达式,比如 1+ 2
, int num = 2
- 这种强制类型转换操作并不改变操作数本身
2. 案例演示
#include<stdio.h>
void main(){
double d1 = 1.934;
int num1 = (int)d1;//注意:不进行四舍五入,而是直接截断小数点的部分
printf("num1=%d d1=%f",num1,d1);
getchar();
}
3. 强制类型转换细节说明
-
- 当进行数据的从 精度高——>精度低,就需要使用到强制转换
- 强转符号只针对于最近的操作数有效,往往会使用小括号提升优先级
- 案例演示:
-
(int)3.5
只针对这个数有效,转成 3
,最后结果 39.0
为double
型,强制转成 int
后去掉 0
int num2 = (int)3.5 * 10 + 6 * 1.5; // 3 * 10 + 6 * 1.5 = 30+9.0 = 39.0
printf("\n num2=%d",num2);
int num3 = (int)(3.5 * 10 + 6 * 1.5); // 35.0+9.0=44.0
printf("\n num3=%d",num2);
4. 基本数据类型转换-练习题
- 判断是编译是否会通过?
char c = 'a';
int i = 5;
float d = .314F;
double result = c+i+d; // c+i+d 类型是 float -> double ok
- 下面的还有一个案例
#include <stdio.h>
void main() {
char c = 'a';
int i = 5;
float d = .314F;
double d2 = 1.0;
//double result = c+i+d; // float -> double
char result = c+i+d+d2; // 提示? // 警告 double -> char
}