在c#中,哪种数据类型最适合赚钱?
当前回答
另一种选择(特别是如果您滚动自己的类)是使用int或int64,并指定后面的四位数字(甚至可能是2)为“小数点的右侧”。所以“在边缘”,你需要一些“* 10000”在入口,一些“/ 10000”在出口。这是微软SQL Server使用的存储机制,请参见http://msdn.microsoft.com/en-au/library/ms179882.aspx
这样做的好处是,所有的求和都可以用(快速的)整数算术来完成。
其他回答
系统。小数
Decimal值类型表示十进制数字,范围从正79,228,162,514,264,337,593,543,950,335到负79,228,162,514,264,337,593,543,950,335。Decimal值类型适用于需要大量有效整数和小数位数且没有舍入错误的财务计算。Decimal类型并不能消除舍入的需要。相反,它最小化了舍入造成的错误。
我想指出zneak关于为什么不应该使用double的出色回答。
十进制的范围更小,但精度更高——所以你不会随着时间的推移失去所有的便士!
详情如下:
http://msdn.microsoft.com/en-us/library/364x0z75.aspx
创建自己的类。这看起来很奇怪,但是. net类型不足以覆盖不同的货币。
小数。如果你选择了double,你就很容易出现舍入错误
使用来自企业应用程序体系结构模式的Money模式。指定金额为十进制,货币为枚举。
推荐文章
- Selenium c# WebDriver:等待元素出现
- 我如何添加双引号的字符串,是在一个变量?
- 检查字符串是否包含字符串列表中的元素
- 最好的方法在asp.net强制https为整个网站?
- 将字符串转换为System.IO.Stream
- IEEE 754浮点数不能精确表示的第一个整数是哪一个?
- 如何从枚举中选择一个随机值?
- 驻留在App_Code中的类不可访问
- 在链式LINQ扩展方法调用中等价于'let'关键字的代码
- dynamic (c# 4)和var之间的区别是什么?
- Visual Studio: ContextSwitchDeadlock
- c++中size_t和int的区别是什么?
- 返回文件在ASP。Net Core Web API
- 自定义HttpClient请求头
- 如果我使用OWIN Startup.cs类并将所有配置移动到那里,我是否需要一个Global.asax.cs文件?