• C语音之基本数据类型转换


    基本数据类型转换

    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. 自动类型转换细节说明

    1. 有多种类型的数据混合运算时,系统首先自动将所有数据转换成精度最大的那种数据类型,然后再进行计算(如 int 型和 short 型运算时,先把 short 转成 int 型后再进行运算)。
    2. 若两种类型的字节数不同,转换成字节数大的类型,若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型
    3. 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边的类型将转换为左边的类型,如果右边变量的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入
    4. 代码演示:
    #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. 强制类型转换细节说明

    1. 当进行数据的从 精度高——>精度低,就需要使用到强制转换
    2. 强转符号只针对于最近的操作数有效,往往会使用小括号提升优先级
    3. 案例演示:
    • (int)3.5 只针对这个数有效,转成 3,最后结果 39.0double型,强制转成 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
    }
    
  • 相关阅读:
    2015年终总结
    拉格朗日插值编程实现
    dlib库使用
    semi-global matching 算法总结
    为什么有的程序在64位机上跑反而比32位机更慢
    编译并使用带有OpenCL模块的OpenCV for android SDK
    Android OpenGL ES 离屏渲染(offscreen render)
    Django的安装和项目的启动
    实现单例模式的几种方法
    基本数据结构----队列
  • 原文地址:https://www.cnblogs.com/xdr630/p/15254610.html
Copyright © 2020-2023  润新知