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

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

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

隐式转换

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

语法

double input = ;int output = input;

登录后复制

算法

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

示例

#include 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: 25.3056The output value is: 25

登录后复制

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

显式转换

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

立即学习“C++免费学习笔记(深入)”;

算法

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

在赋值期间提及数据类型

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

C 风格版本

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

语法

double input = ;int output = (int) input;

登录后复制

示例

#include 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: 84.4439The value after conversion: 84

登录后复制

函数式铸造

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

语法

double input = ;int output = int(input);

登录后复制

示例

#include 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: -993.657The value after conversion: -993

登录后复制

使用 static_cast

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

语法

double input = ;int output = static_cast(input);

登录后复制

示例

#include using namespace std;int solve(double value) {   int opVal = static_cast(value);   return opVal;}int main(){   double ip = -65.2354;   int op = solve(ip);   cout

输出

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

登录后复制

结论

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

以上就是C++程序将double类型的变量转换为int类型的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2587718.html

(0)
上一篇 2025年3月6日 15:40:40
下一篇 2025年3月5日 19:48:06

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论