如何将小数转换为整型?
当前回答
你不能。
当然可以,但是int (System.Int32)不足以容纳所有可能的十进制值。
这意味着如果你强制转换一个比int大的小数。MaxValue会溢出,如果小数点小于int。MinValue,它会溢出。
当你不足/溢出时会发生什么?两件事之一。如果您的构建是未检查的(即,CLR并不关心您是否这样做),您的应用程序将在值溢出/下溢之后继续运行,但int中的值将不是您所期望的值。这可能会导致间歇性的错误,并且可能很难修复。您的应用程序最终将处于未知状态,这可能会导致应用程序破坏它所处理的任何重要数据。不好的。
如果您的程序集被选中(properties->build->advanced->check for算术溢出/下溢或/checked compiler选项),则在发生下溢/溢出时,代码将抛出异常。这可能比没有好;但是,程序集的默认值是不检查溢出/溢出。
真正的问题是“你想做什么?”在不知道你的需求的情况下,没有人能告诉你在这种情况下应该做什么,除了显而易见的:不要这样做。
如果你特别不在乎,这里的答案是有效的。但是,您应该传达您的理解,即可能发生溢出,并且将强制转换代码包装在未检查的块中无关紧要
unchecked
{
// do your conversions that may underflow/overflow here
}
这样,后面的人就会明白你不在乎,如果将来有人把你的构建改为/checked,你的代码就不会意外地崩溃。
如果你想要做的只是去掉数字的小数部分,留下整数部分,你可以使用Math.Truncate。
decimal actual = 10.5M;
decimal expected = 10M;
Assert.AreEqual(expected, Math.Truncate(actual));
其他回答
decimal vIn = 0.0M;
int vOut = Convert.ToInt32(vIn);
这是一个非常方便的转换数据类型的网页,为那些其他人。 http://www.convertdatatypes.com/Convert-decimal-to-int-in-CSharp.html
四舍五入小数到最接近的整数
decimal a ;
int b = (int)(a + 0.5m);
当a = 49.9时,b = 50
当a = 49.5时,b = 50
当a = 49.4时,b = 49,以此类推。
使用转换。从mscorlib中的ToInt32
decimal value = 3.14m;
int n = Convert.ToInt32(value);
看到MSDN。你也可以使用Decimal.ToInt32。同样,请参见MSDN。最后,你可以直接转换为
decimal value = 3.14m;
int n = (int) value;
它使用显式强制转换操作符。看到MSDN。
系统。Decimal实现了IConvertable接口,该接口有一个ToInt32()成员。
调用System.Decimal.ToInt32()工作吗?
十进制d = 5.5;
int i = decimal.ToInt32(d);// you will get i = 5
参考:链接文本
推荐文章
- 实体框架核心:在上一个操作完成之前,在此上下文中开始的第二个操作
- 如何为构造函数定制Visual Studio的私有字段生成快捷方式?
- 为什么Visual Studio 2015/2017/2019测试运行器没有发现我的xUnit v2测试
- 如何使用JSON确保字符串是有效的JSON。网
- AppSettings从.config文件中获取值
- 通过HttpClient向REST API发布一个空体
- 如何检查IEnumerable是否为空或空?
- 自动化invokerrequired代码模式
- 没有ListBox。SelectionMode="None",是否有其他方法禁用列表框中的选择?
- 在c#代码中设置WPF文本框的背景颜色
- 在c#中,什么是单子?
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 如何舍入一个双到最近的Int在迅速?
- c#线程安全快速(est)计数器
- 如何将此foreach代码转换为Parallel.ForEach?