请问double型可以强制转换成int型吗?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了请问double型可以强制转换成int型吗?相关的知识,希望对你有一定的参考价值。

double类型可以强制转换成int类型。

可以通过显式强制类型转换、隐式强制类型转换两种方式进行转换。

1、显式强制类型转换

格式为:int b = (int) a;

经强制类型转换运算符运算后,返回一个具有int类型的数值,这种强制类型转换操作并不改变操作数本身,运算后操作数本身未改变。

2、隐式强制类型转换

隐式类型转换发生在赋值表达式和有返回值的函数调用表达式中。在赋值表达式中,如果赋值符左右两侧的操作数类型不同,则将赋值符右边操作数强制转换为赋值符左侧的类型数值后,赋值给赋值符左侧的变量。

在函数调用时,如果return后面表达式的类型与函数返回值类型不同,则在返回值时将return后面表达式的数值强制转换为函数返回值类型后,再将值返回。例如:

int n;double d=3.78;n=d;

执行完后,n的值为3,而d的值仍是3.78。

扩展资料:

自动类型遵循的规则:

1、若参与运算量的类型不同,则先转换成同一类型,然后进行运算。

2、转换按数据长度增加的方向进行,为保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。

3、所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。

4、char型和short型参与运算时,必须先转换成int型。

5、在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边大时,将丢失一部分数据,这样会降低精度,丢失的部分直接舍去。

参考资料来源:百度百科-强制类型转换

参考技术A double型可以强制转换成int型,即使不加强制转换,也会隐式转换,只是转换结果会丢弃小数部分,如:
double d=1.6;
int i;
i=d ; //隐式转换,i结果为1
i=(int)d ; //强制转换,i结果为1
但,如果double变量数据,超过整形数据的表示范围,(一般整数占四个字节,有符号数表示范围为:-2^31 ~ 2^31-1 ),则转换后的结果会是错误的。

c#中怎么把double类型转换成int类型

第一种 强制类型转换

double d=1.5;

int i=(int)d;

这种方式的话采取的是截位,意思就是去掉小数点后的数字,比如1.8,结果是1,如果是1.9999999,那结果也是1;

第二种 使用Round函数:

double d=1.6;

int i = Math.Round(d, 0);(保留0维小数就是取整)

第二个参数表示的是保留的小数位数,使用Round函数是四舍五入,而不是截位,比如是1.4,那结果就是1,是1.5,结果就是2

扩展资料:

double类型转换成int类型例题:

int16=short;

int32=int;

int64=long;

double转成int时候会涉及都小数,看你像对小数做什么操作了,以3.8为例子:

int num = Math.Floor(3.8)//返回小于或等于指定数字的最大整数,结果为3

int num = Math.Round(3.8)//将值舍入到最接近的整数或指定的小数位数,结果为4

参考技术A 第一种 强制类型转换
double d=1.5;
int i=(int)d;
这种方式的话采取的是截位,也就是不管小数部分是多少,统统舍弃,哪怕是1.9,转换完也是1
第二种 使用Round函数
double d=1.6
int i = Math.Round(d, 0);(保留0维小数就是取整)
第二个参数表示要保留的小数位数
使用Round函数是四舍五入,而不是截位

使用哪种方式转换根据你的实际需要来本回答被提问者采纳
参考技术B int a=double.Parse(***); 参考技术C double a = 123.0;
int b = (int)a;
参考技术D

第一种 强制类型转换
double d=1.5;
int i=(int)d;


这种方式的话采取的是截位,也就是不管小数部分是多少,统统舍弃,哪怕是1.9,转换完也是1

第二种 使用Round函数
double d=1.6
int i = Math.Round(d, 0);(保留0维小数就是取整)


第二个参数表示要保留的小数位数
使用Round函数是四舍五入,而不是截位

使用哪种方式转换根据你的实际需要来

以上是关于请问double型可以强制转换成int型吗?的主要内容,如果未能解决你的问题,请参考以下文章

在QT中如何将double转换为Qstring

在C#中如何将int类型强制转换为double类型

请问C语言中如何将int转换为float

c#中怎么把double类型转换成int类型

C语言的浮点型怎么转换为整型?

JAVA:string类型转换int(16进制)