C 语言编程 — 数据类型转换

目录

前文列表

程序编译流程与 GCC 编译器
C 语言编程 — 基本语法
C 语言编程 — 基本数据类型
C 语言编程 — 变量与常量
C 语言编程 — 运算符
C 语言编程 — 逻辑控制语句
C 语言编程 — 函数
C 语言编程 — 高级数据类型 — 指针
C 语言编程 — 高级数据类型 — 数组
C 语言编程 — 高级数据类型 — 枚举
C 语言编程 — 高级数据类型 — 结构体与位域
C 语言编程 — 高级数据类型 — 共用体
C 语言编程 — 数据类型的别名

数据类型转换

C 语言中如果一个表达式中含有不同类型的常量和变量,在计算时,会将它们自动转换为同一种类型。此外,在 C 语言中也可以对数据类型进行强制转换。

在编程时,有需要类型转换的时候都用上强制类型转换运算符,是一种良好的编程习惯。

隐式(自动)类型转换

  • 浮点数赋给整型,该浮点数小数被舍去;
  • 整数赋给浮点型,数值不变,但是被存储到相应的浮点型变量中;
#include <stdio.h>
 
int main(){
   int  i = 17;
   char c = 'c'; /* ascii 值是 99 */
   int sum;
 
   sum = i + c;
   printf("Value of sum : %d\n", sum );
 
}

常用的算术转换

常用的算术转换是隐式地把值强制转换为相同的类型。编译器首先执行整数提升(把小于 int/unsigned int 的整数类型自定转换为 int/unsigned int 的过程),如果操作数类型不同,则它们会被转换为下列层次中出现的最高层次的类型:

在这里插入图片描述
注意,常用的算术转换不适用于赋值运算符以及逻辑运算符。

显式(强制)类型转换

强制类型转换是把变量从一种类型转换为另一种数据类型。例如,如果您想存储一个 long 类型的值到一个简单整型中,就需要把 long 类型强制转换为 int 类型。此时,就可以使用 强制类型转换运算符(类型标识符)(表达式)

#include <stdio.h>

int main() {
    float f, a, x=3.6, y=5.2;
    int i=4, b;
    a = x + y;
    b = (int)(x + y);
    f = 10 / i;

    printf("a=%d, b=%d, f=%f, x=%f\n", a, b, f, x);
    return 0;
}

运行:

$ ./main
a=8.799999, b=8, f=2.000000, x=3.600000
#include <stdio.h>

int main() {
    int sum = 17, count = 5;
    double mean;

    mean = (double)sum / count;
    // mean = (double)(sum / count);  此时返回 3.000000
    printf("Value of mean: %f", mean);
    return 0;
}

需要注意的是,强制类型转换运算符的优先级大于除法,因此 sum 的值首先被转换为 double 型,然后除以 count,得到一个类型为 double 的值。注意,如果是 (double)(sum / count) 的话,则会先进行整数运算得到 3 再类型转换为双精度浮点数 3.000000。

运行:

$ ./main
Value of mean: 3.400000
发布了500 篇原创文章 · 获赞 1352 · 访问量 188万+

猜你喜欢

转载自blog.csdn.net/Jmilk/article/details/105309263