目录
隐式转换
语法
算法
示例
输出
显式转换
在赋值期间提及数据类型
C 风格版本
函数式铸造
使用 static_cast
结论
首页 后端开发 C++ C++程序将double类型的变量转换为int类型

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

Aug 25, 2023 pm 08:25 PM
double int 转换类型

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

在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
登录后复制

结论

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

以上是C++程序将double类型的变量转换为int类型的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP中int类型转换为字节的方法详解 PHP中int类型转换为字节的方法详解 Mar 06, 2024 pm 06:18 PM

PHP中int类型转换为字节的方法详解在PHP中,我们经常需要将整数类型(int)转换为字节(Byte)类型,比如在处理网络数据传输、文件处理或者加密算法等场景中。本文将详细介绍如何将int类型转换为字节类型,以及提供具体的代码示例。1.int类型与字节的关系在计算机领域,基本数据类型int表示整数,而字节(Byte)是计算机存储单位,通常是8位二进制数据

C++程序将double类型的变量转换为int类型 C++程序将double类型的变量转换为int类型 Aug 25, 2023 pm 08:25 PM

在C++中,int类型的变量只能保存正整数或负整数值;它们不能保存小数值。有float和double值可用于此目的。为了存储小数点后最多七位的小数,创建了双精度数据类型。整数到双精度数据类型的转换可以由编译器自动完成(称为“隐式”转换),也可以由程序员向编译器显式请求(称为“显式”转换)。在接下来的部分中,我们将介绍各种转换方法。隐式转换编译器自动执行隐式类型转换。要实现这一点,需要两个变量——一个是浮点类型,另一个是整数类型。当我们简单地将浮点值或变量分配给整数变量时,编译器将处理所有其他事情

int32的取值范围是多少 int32的取值范围是多少 Aug 11, 2023 pm 02:53 PM

int32的取值范围是从-2的31次方到2的31次方减1,即-2147483648到2147483647。int32是有符号的整数类型,意味着它可以表示正数、负数和零,它使用1位来表示符号位,而剩余的31位用来表示数值。由于一位被用来表示符号位,所以int32的有效位数是31位。

int占几个字节 int占几个字节 Jan 22, 2024 pm 03:14 PM

int类型在不同编程语言和不同硬件平台下所占用的字节数可能会有所不同。详细介绍:1、在C语言中,int类型通常占用2个字节或4个字节。在32位系统中,int类型占用4个字节,而在16位系统中,int类型占用2个字节。在64位系统中,int类型可能占用8个字节;2、在Java中,int类型通常占用4个字节,而在Python中,int类型没有字节数限制,可以自动调整等等。

go语言怎么将int转为字符串类型 go语言怎么将int转为字符串类型 Jun 04, 2021 pm 03:56 PM

转换方法:1、使用Itoa()函数,语法“strconv.Itoa(num)”;2、使用FormatInt()函数,可将int型数据转换成指定进制并以字符串的形式返回,语法“strconv.FormatInt(num,10)”。

java int 是几位 java int 是几位 Mar 06, 2023 pm 04:09 PM

在java中,int是32位有符号数据类型,其变量需要32位内存;int数据类型的有效范围为-2147483648至2147483647,此范围中的所有整数称为整数字面量。一个整数字面量可以分配给一个int变量,例如“int num1 = 21;”。

double占几个字节 double占几个字节 Dec 25, 2020 am 10:36 AM

double占的字节:1、16位编译器下,double占8个字节;2、32位编译器下,double占8个字节;3、64位编译器下,double占8个字节。

vb中int是什么意思 vb中int是什么意思 Dec 03, 2020 am 09:48 AM

vb中int是指取整数的函数,其语法如“int(x)”,表示取不大于x的最大整数;和int函数功能类似的函数还有Fix函数,该函数会删除小数部分而返回剩下的整数。

See all articles