c#中,数字型有“定点小数型”吗,double型是浮点型,精度高吗?

fqfqfqfq5 2011-09-08 08:46:26
c#中,数字型有“定点小数型”吗,double型是浮点型,精度高吗?
----------------------------------------------------------
在 sqlserver 中,小数分为 浮点型 与 定点小数型。用浮点型的计算误差比较大。所以一般计算要用定点小数型。
即 不用 float 二用 numeric

但是,我想问,在c#中,哪一种是精度搞的小数型呢?
double是浮点型,用它计算会不会有误差呢?

如果想提高计算精度,用什么类型呢?
...全文
430 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
dulei123321 2011-09-08
  • 打赏
  • 举报
回复
C#中有int decimal(浮点型)
  • 打赏
  • 举报
回复
Decimal 高精度小数 常用于财务上 建议使用
Double 32位浮点小数
float 16位浮点小数
funxu 2011-09-08
  • 打赏
  • 举报
回复
double 的误差主要是源于错误的操作,比如强制转换,或者不经意的强制转换
例如
int a = (int)(19.9 *100) =1989
int b = (int)(19.9M *100 )=1990
tinysun1989 2011-09-08
  • 打赏
  • 举报
回复
其实浮点型都是有误差的,只不过小数位数越多,误差越小而已
float是7位小数
double是15/16位
decimal是28位,给你一个链接吧,这里面有比较详细的介绍误差值
http://www.cnblogs.com/quietwalk/archive/2010/05/02/1725885.html
sanjiawan 2011-09-08
  • 打赏
  • 举报
回复
在c#中,哪一种是精度搞的小数型呢?
可以用decimal

double是浮点型,用它计算会不会有误差呢?
只要是浮点型 就会有数据损失 就会有误差

如果想提高计算精度,用什么类型呢?
decimal就可以了 还有一种高精度的算法 你有兴趣研究下 我还没研究过 呵呵
萧炎 2011-09-08
  • 打赏
  • 举报
回复
decimal
余山水 2011-09-08
  • 打赏
  • 举报
回复
Decimal(他可以保存精确浮点型,不会有误差)double有误差的.
诺维斯基 2011-09-08
  • 打赏
  • 举报
回复
C#中有int decimal(浮点型)
没法下载,到这里折腾一把试试。 本文由abc2253130贡献 doc文档可能在WAP端浏览体验不佳。建议您优先选择TXT,或下载源文件到本机查看。 C#(WINFORM)学习 一、 C#基础 基础 类和变量 类和变量 类 C# 支持两种类:“值类”和“引用类”。值类包括简单类(如 char、int 和 float 等)、枚举类和结构类。引用类包括类 (Class)类 、接口类、委托类和数组类。 变量的类声明 变量的类声明 每个变量必须预先声明其类。如 int a; int b = 100; float j = 4.5; string s1; 用 object 可以表示所有的类。 预定义类 下表列出了预定义类,并说明如何使用。 类 object 说明 所有其他类的最终 基类 字符串类; 字符串是 Unicode 字符序列 8 位有符号整 16 位有符号整 32 位有符号整 64 位有符号整 示例 object o = null; 范围 string sbyte short int long string s = "hello"; sbyte val = 12; short val = 12; int val = 12; long val1 = 12; -128 到 127 -32,768 到 32,767 -2,147,483,648 2,147,483,647 -9,223,372,036,854,775,808 到 第1页 C#(WINFORM)学习 long val2 = 34L; 到 9,223,372,036,854,775,807 byte ushort 8 位无符号整 16 位无符号整 byte val1 = 12; ushort val1 = 12; uint val1 = 12; uint 32 位无符号整 uint val2 = 34U; ulong val1 = 12; ulong val2 = 34U; ulong 64 位无符号整 ulong val3 = 56L; ulong val4 = 78UL; float 单精度浮点 float val = 1.23F;7 位 double val1 = 1.23; double 双精度浮点 double val2 = ±5.0 × 10?324 ±1.7 × 10 308 0 到 255 0 到 65,535 0 到 4,294,967,295 0 到 18,446,744,073,709,551,615 ±1.5 × 10?45 ±3.4 × 10 38 到 到 4.56D;15-16 布尔;bool 值或为 真或为假 字符类;char 值是 一个 Unicode 字符 精确的小数, 具有 28 个有效数字 bool val1 = true; bool val2 = false; char val = 'h'; decimal val = bool char decimal DateTime ±1.0 × 10?28 ±7.9 × 10 28 到 1.23M;28-29 变量转换 简单转换: float f = 100.1234f; 可以用括号转换: short s = (short)f 也可以利用 Convert 方法来转换: string s1; s1=Convert.ToString(a); MessageBox.Show(s1); 常用 Convert 方法有: 第2页 C#(WINFORM)学习 C# Convert.ToBoolean Convert.ToByte Convert.ToChar Convert.ToDateTime Convert.ToDecimal Convert.ToDouble Convert.ToInt16 Convert.ToInt32 Convert.ToInt64 Convert.ToSByte Convert.ToSingle Convert.ToString Convert.ToUInt16 Convert.ToUInt32 Convert.ToUInt64 备注 Math 类 常用科学计算方法: C# Math.Abs Math.Sqrt Math.Ro

110,499

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧