c# 计算后的double怎么四舍五入转int
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c# 计算后的double怎么四舍五入转int相关的知识,希望对你有一定的参考价值。
如图是是将计算后的结果值赋给int,但是怎么实现四舍五入后才存入int呢?
用Math.Ceiling,这是向上进位取整函数。例如:Math.Ceiling(32.4) 结果是33; Math.Ceiling(32.0) 结果是 32
与此对应的是向下舍位取整 Math.Floor。
例如: Math.Floor(32.6) 结果是32追问
我其实知道这个方法,但是没理解多少,刚才看了下,发现这方法返回的是double类型,那么一切都好说了,谢谢提醒
参考技术A Math.Round(你的数, MidpointRounding.AwayFromZero)追问谢谢
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函数是四舍五入,而不是截位
使用哪种方式转换根据你的实际需要来
以上是关于c# 计算后的double怎么四舍五入转int的主要内容,如果未能解决你的问题,请参考以下文章