首页 > 文章列表 > C++程序将double类型的变量转换为int类型

C++程序将double类型的变量转换为int类型

int double 转换类型
302 2023-08-29

在C++中,int类型的变量只能保存正整数或负整数值;它们不能保存小数值。有 float 和 double 值可用于此目的。为了存储小数点后最多七位的小数,创建了双精度数据类型。整数到双精度数据类型的转换可以由编译器自动完成(称为“隐式”转换),也可以由程序员向编译器显式请求(称为“显式”转换)。在接下来的部分中,我们将介绍各种转换方法。

隐式转换

编译器自动执行隐式类型转换。要实现这一点,需要两个变量——一个是浮点类型,另一个是整数类型。当我们简单地将浮点值或变量分配给整数变量时,编译器将处理所有其他事情。此转换存在数据丢失的问题,因为整数变量不能包含小数点后的小数值。

语法

double input = <double value>;
int output = input;

算法

  • 以双精度值作为输入;
  • 将值赋给整型变量。
  • 显示输出。

示例

#include <iostream>
using namespace std;

int solve(double value) {
   int opVal = value;
   return opVal;
}

int main()
{
   double ip = 25.3056;
   int op = solve(ip);
   cout<< "The input value is: " << ip << endl;
   cout<< "The output value is: " << op << endl;
   return 0;
}

输出

The input value is: 25.3056
The output value is: 25

正如我们所看到的,转换过程相当简单。我们只是将输入变量分配给输出变量;不需要额外的程序。另外,可以看出输出中不存在双精度值的小数部分。

显式转换

当程序员显式指示编译器将一种数据类型转换为另一种数据类型时,这称为显式转换或显式类型转换。有两种方法可以实现此目的:一种是在赋值时显式声明数据类型,另一种是使用 static_cast。我们之前讨论过第一种方法。

算法

  • 以双精度值作为输入;
  • 使用显式类型转换将值分配给整数变量。
  • 显示输出。

在赋值期间提及数据类型

有两种不同的执行方式。一种是 C 风格的版本,另一种是函数风格的转换。

C 风格版本

结果数据类型在源变量之前指定,并括在括号内。

语法

double input = <double value>;
int output = (int) input;

示例

#include <iostream>
using namespace std;

int solve(double value) {
   int opVal = (int)value;
   return opVal;
}

int main()
{
   double ip = 84.4439;
   int op = solve(ip);
   cout<< "The value before conversion: " << ip << endl;
   cout<< "The value after conversion: " << op << endl;
   return 0;
}

输出

The value before conversion: 84.4439
The value after conversion: 84

函数式铸造

当向函数提供参数时,我们会声明结果数据类型并将源值括在括号内。

语法

double input = <double value>;
int output = int(input);

示例

#include <iostream>
using namespace std;

int solve(double value) {
   int opVal = int(value);
   return opVal;
}

int main()
{
   double ip = -993.6571;
   int op = solve(ip);
   cout<< "The value before conversion: " << ip << endl;
   cout<< "The value after conversion: " << op << endl;
   return 0;
}

输出

The value before conversion: -993.657
The value after conversion: -993

使用 static_cast

要在预定义类型之间进行转换,请使用静态强制转换。此外,这个也可以显式引用的强制转换负责强制执行隐式类型转换。

语法

double input = < double value>;
int output = static_cast<int>(input);

示例

#include <iostream>
using namespace std;

int solve(double value) {
   int opVal = static_cast<int>(value);
   return opVal;
}

int main()
{
   double ip = -65.2354;
   int op = solve(ip);
   cout<< "The value before conversion: " << ip << endl;
   cout<< "The value after conversion: " << op << endl;
   return 0;
}

输出

The value before conversion: -65.2354
The value after conversion: -65

结论

从双精度数据类型转换为整型数据类型总是会导致数据丢失,因为整型变量不能包含双精度变量的小数部分。当我们必须将一个值四舍五入到其下限值(给定小数值的最小整数值)时,这些转换非常有用。