int、float、double In .Net之相互转换

最近在检查我们公司某台Server时,发现Windows日志中记录了很多SystemToNumber的Crash Exception,问题原因为公司的同事Coding时都犯了一个最基本的原则性错误,鉴于此,觉得还是有必要再梳理下.Net中三个基本的数值类型(int、float、double),。

Int :在.NET中,int是有符号的32位整型数值 ,无论处理器是32位还是64位,它的.NET框架类型是System.Int32 。                                                     

Float:单精度浮点数,32位长度,1位实数符号位(原码表示),1位指数符号位,7位指数位(此八位为移码表示)以及23位数据位(补码表示),在.net中又称为Single。

Double: 64位长度的双精度浮点数,1位符号位,11位指数位,52位数据位。

三者的转换关系:

1. int可以隐式转换成float和double;

2.float只能强制转换成int,但是可以隐式转换成double;

3.double只能强制转换成float和int。

PS:

注意区分:(1)Convert.ToInt32("56.89")  和  (2)Convert.ToInt(56.89)

(1)的这种写法会导致抛出FormatException,所以要用(2)这种写法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值