C 语言中的类型转换:类型转换、隐式转换、显式转换(附示例)
C 语言中的类型转换是什么?
类型转换是将一种数据类型转换为另一种数据类型。在 C 语言中,它也被称为数据转换或类型转换。它是“C”编程中引入的重要概念之一。
“C”编程提供了两种类型的类型转换操作:
- 隐式类型转换
- 显式类型转换
隐式类型转换
隐式类型转换是指在不丢失原有含义的情况下转换数据类型。当您想要更改数据类型时,这种类型的类型转换是必不可少的 也完全不需要 改变存储在 变量.
当将值复制到其兼容数据类型时,C 中的隐式类型转换会自动发生。在转换过程中,会应用严格的类型转换规则。如果操作数属于两种不同的数据类型,则具有较低数据类型的操作数会自动转换为较高的数据类型。以下示例中可以看到这种类型的类型转换。
#include<stdio.h> int main(){ short a=10; //initializing variable of short data type int b; //declaring int variable b=a; //implicit type casting printf("%d\n",a); printf("%d\n",b); }
输出:
10 10
- 在给定的示例中,我们声明了一个短数据类型的变量,其值初始化为 10。
- 在第二行,我们声明了一个 int 数据类型的变量。
- 在第三行,我们将变量 s 的值赋给了变量 a。在第三行,执行了隐式类型转换,因为将 short 数据类型的变量 s 的值复制到 int 数据类型的变量 a 中。
将字符转换为整数
考虑将 ASCII 解码后的字符与整数相加的示例:
#include <stdio.h> main() { int number = 1; char character = 'k'; /*ASCII value is 107 */ int sum; sum = number + character; printf("Value of sum : %d\n", sum ); }
输出:
Value of sum : 108
这里,编译器在执行实际的加法运算之前,通过将“k”的值转换为 ASCII,进行了整数提升。
算术转换层次结构
编译器首先将字符提升为整数。如果操作数仍然具有不同的数据类型,则它们将转换为以下层次结构图中显示的最高数据类型:
考虑以下示例来理解这个概念:
#include <stdio.h> main() { int num = 13; char c = 'k'; /* ASCII value is 107 */ float sum; sum = num + c; printf("sum = %f\n", sum );}
输出:
sum = 120.000000
首先,c 变量被转换为整数,但编译器会转换 NUM 和 c 变成“float”,并将它们相加以产生“float”结果。
关于隐式转换的要点
- 隐式类型转换也称为标准类型转换。在隐式类型转换中,我们不需要任何关键字或特殊语句。
- 从较小的数据类型转换为较大的数据类型也称为 类型促销在上面的例子中,我们还可以说s的值被提升为整型。
- 隐式类型转换总是发生在兼容的数据类型中。
我们不能对彼此不兼容的数据类型执行隐式类型转换,例如:
- 将浮点数转换为整数将会截断小数部分,从而失去值的意义。
- 将双精度型转换为浮点型将会对数字进行四舍五入。
- 将 long int 转换为 int 将导致丢弃多余的高位。
以上所有情况,当我们转换数据类型时,值都会失去意义。一般情况下,编译器会警告值失去意义。
C 语言编程 提供了另一种类型转换的方式,即显式类型转换。
显式类型转换
在隐式类型转换中,数据类型会自动转换。在某些情况下,我们可能必须强制进行类型转换。假设我们有一个变量 div,它存储两个操作数的除法,这两个操作数被声明为 int 数据类型。
int result, var1=10, var2=3; result=var1/var2;
在这种情况下,对变量 var1 和 var2 执行除法后,变量“result”中存储的结果将为整数格式。每当发生这种情况时,变量“result”中存储的值就会失去其意义,因为它没有考虑两个数字除法中通常会得到的小数部分。
为了在这种情况下强制进行类型转换,我们使用显式类型转换。
它需要一个类型转换运算符。类型转换操作的一般语法如下:
(type-name) expression
在这里,
- 类型名称是标准的“C”语言数据类型。
- 表达式可以是常量、变量或实际表达式。
让我们编写一个程序来演示如何使用显式类型转换在 C 中进行类型转换。
#include<stdio.h> int main() { float a = 1.2; //int b = a; //Compiler will throw an error for this int b = (int)a + 1; printf("Value of a is %f\n", a); printf("Value of b is %d\n",b); return 0; }
输出:
Value of a is 1.200000 Value of b is 2
- 我们已经初始化了 float 类型的变量“a”。
- 接下来,我们有另一个整数数据类型的变量“b”。由于变量“a”和“b”属于不同的数据类型,“C”不允许使用这样的表达式,并且会引发错误。在某些版本的“C”中,表达式将被求值,但结果并不理想。
- 为了避免这种情况,我们将变量“a”转换为浮点型。通过使用显式类型转换方法,我们成功地将浮点型转换为整数数据类型。
- 我们打印了 'a' 的值,它仍然是一个浮点数
- 经过类型转换后,结果将始终是一个整数“b”。
通过这种方式,我们就可以在 C 编程中实现显式类型转换。
总结
- 类型转换又称为类型转换
- 它的意思是将一种数据类型转换为另一种数据类型。
- 将较小的数据类型转换为较大的数据类型也称为类型提升。
- C 语言中有两种类型转换:隐式类型转换和显式类型转换。
- 当找到兼容的数据类型时,隐式类型转换会自动运行。
- 显式类型转换需要类型转换运算符。
处理不同数据类型时,请记住以下编程实践规则,以防止数据丢失:
- 整数类型应该转换为浮点数。
- 浮点型应该转换为双精度型。
- 字符类型应该转换为整数。