C 语言中的类型转换:类型转换、隐式转换、显式转换(附示例)

C 语言中的类型转换是什么?

类型转换是将一种数据类型转换为另一种数据类型。在 C 语言中,它也被称为数据转换或类型转换。它是“C”编程中引入的重要概念之一。

“C”编程提供了两种类型的类型转换操作:

  1. 隐式类型转换
  2. 显式类型转换

隐式类型转换

隐式类型转换是指在不丢失原有含义的情况下转换数据类型。当您想要更改数据类型时,这种类型的类型转换是必不可少的 也完全不需要 改变存储在 变量.

当将值复制到其兼容数据类型时,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

隐式类型转换

  1. 在给定的示例中,我们声明了一个短数据类型的变量,其值初始化为 10。
  2. 在第二行,我们声明了一个 int 数据类型的变量。
  3. 在第三行,我们将变量 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的值被提升为整型。
  • 隐式类型转换总是发生在兼容的数据类型中。

我们不能对彼此不兼容的数据类型执行隐式类型转换,例如:

  1. 将浮点数转换为整数将会截断小数部分,从而失去值的意义。
  2. 将双精度型转换为浮点型将会对数字进行四舍五入。
  3. 将 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

显式类型转换

  1. 我们已经初始化了 float 类型的变量“a”。
  2. 接下来,我们有另一个整数数据类型的变量“b”。由于变量“a”和“b”属于不同的数据类型,“C”不允许使用这样的表达式,并且会引发错误。在某些版本的“C”中,表达式将被求值,但结果并不理想。
  3. 为了避免这种情况,我们将变量“a”转换为浮点型。通过使用显式类型转换方法,我们成功地将浮点型转换为整数数据类型。
  4. 我们打印了 'a' 的值,它仍然是一个浮点数
  5. 经过类型转换后,结果将始终是一个整数“b”。

通过这种方式,我们就可以在 C 编程中实现显式类型转换。

总结

  • 类型转换又称为类型转换
  • 它的意思是将一种数据类型转换为另一种数据类型。
  • 将较小的数据类型转换为较大的数据类型也称为类型提升。
  • C 语言中有两种类型转换:隐式类型转换和显式类型转换。
  • 当找到兼容的数据类型时,隐式类型转换会自动运行。
  • 显式类型转换需要类型转换运算符。

处理不同数据类型时,请记住以下编程实践规则,以防止数据丢失:

  • 整数类型应该转换为浮点数。
  • 浮点型应该转换为双精度型。
  • 字符类型应该转换为整数。