Decimal 的特殊性和在代码中使用checked

本文深入探讨了C#中基元类型的基础知识,特别是Decimal值的处理方式及其与性能的关系。详细解释了Decimal作为基元类型的特点,如何在CLR中被编译为代码,以及其在金融计算中的应用。同时,文章对比了基元类型如string与String的区别,以及int与Int32的映射关系。最后,提供了检查运算溢出的方法和Decimal运算可能引发的异常处理策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  编译器直接支持的数据类型就是基元类型。基元类型直接映射到Framework类库(FCL)中存在的类型。

  Decimal在C#中是基元类型。FCL是System.Decimal。常用于不容许舍入误差的金融计算。但是Decim

al在CLR中没有相应的IL指令来决定如何处理一个Decimal值。所以当你用Decimal值时。编译Decimal,编译器

会生成代码来调用Decimal的成员,并通过这些成员来执行实际的运算。所以Decimal处理会慢于其他基元类型

。而且,因为没有IL指令处理Decimal值,所以checked和Unchecked操作符、语句以及编译器开关都失去了作

用。假如对Decimal值执行的运算不安全,肯定会抛出异常OverflowException。

  基元类型名称的一些小特点。比如string和String。也许会纠结到底应该使用哪个。因为C#的string直接映

射到System.String(FCL),所以两个一样,都可以用,还有最奇葩的问题int和Int32的区别。在C#中,int始终

映射到System.Int32,所以不管怎么样,在什么操作系统什么的64,32什么的,他始终映射到System.Int32。

代表32位整数。

   基元类型的运算很有可能造成溢出:Byte b=100; b=(Byte)(b+200);C#有一个快捷的设置检查溢出的

方法。在MSVS中点开项目的属性对话框,选择“生成”选项卡,点击“高级”,在勾选“检查运算上溢/下溢”。当然

肯定因为checked运算会造成些许性能损失。但是可以防止应用程序在包含已损坏的数据(甚至是安全漏洞)的

前提下继续运行。

  嗯,虽然J.R建议不要用基元类型名称,多多使用FCL类型名称,额。。。

 

 

转载于:https://www.cnblogs.com/lys911/archive/2012/06/11/2545085.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值