C#double类型数据自动转化为科学计数法

zidianren11 2016-10-11 09:48:35
C#过程中遇到这样一个问题,程序里定义了一个double类型变量,从数据库查询出一个数值A赋值给这个变量,A这个数值是50000000000000000或50000022000000000或50000000000000043时程序会自动将其转化为科学计数,转化之后的分别为5E+16,5.0000022E+16,5E+16。而当A这个数值为50000022001200048时程序未将其转化为科学计数,显示仍然为5000002200120008,为什么此种情况程序未自动转化为科学计数。
...全文
2277 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
秋的红果实 2018-03-21
  • 打赏
  • 举报
回复
做了测试,50000022001200047输出是50000022001200000,保留了前面15位有效数字,末尾的47抹去,成了00
  • 打赏
  • 举报
回复
上述a、b说明了,字符串 b 值因为“反向分析”与原数值一致,所以它实际上使用
string.Format("{0:G}", (double)50000000000000000)
来格式化的。而对于 a 的值,由于字符串反向分析与double 值不一致,所以使用17位精度的字符串格式方式。
  • 打赏
  • 举报
回复
你可以测试一下
var a = string.Format("{0:R}", (double)50000022001200047);
var b = string.Format("{0:R}", (double)50000000000000000);
的输出。 但是这个不是最重要的,最重要的是高层的设计思路和分层思路正确,这样才能不走偏。
秋的红果实 2018-03-21
  • 打赏
  • 举报
回复
double有效位数是15位,你50000022001200048.0。是不是贴错了,小数点前应该是15位而不是16位
  • 打赏
  • 举报
回复
要知道“改变”的是调试器“快速监视窗口”上的文本,并不是 double 数据本身。表现层定义它自己的格式化方法,跟数据本身的含义无关,表现层跟数据模型是分离的。 所以你首先要有“这个窗口为什么这样格式化 double”的意识,而不是认为从数据库读取出来的 double 值也因此改变了。
  • 打赏
  • 举报
回复
引用 8 楼 caozhy 的回复:
没看明白,你是希望这样还是不希望这样
lz 认为 double 自己会 72 变,所以生怕 double 值在不同环境下乱变。
rjw_999 2018-03-21
  • 打赏
  • 举报
回复
那只是显示方式而已,double变量本身里面的东西是不会变的
  • 打赏
  • 举报
回复
给你抄一段 msdn:
R 或 r
往返过程
只有 Single 和 Double 类型支持此格式。往返过程说明符保证转换为字符串的数值再次被分析为相同的数值。使用此说明符格式化数值时,首先使用常规格式对其进行测试:Double 使用 15 位精度,Single 使用 7 位精度。如果此值被成功地分析回相同的数值,则使用常规格式说明符对其进行格式化。但是,如果此值未被成功地分析为相同数值,则它这样格式化:Double 使用 17 位精度,Single 使用 9 位精度。
虽然此处可以存在精度说明符,但它将被忽略。使用此说明符时,往返过程优先于精度。 
double 永远也不会胡乱改变,改变的是 string 格式化结果,而不是什么 double 被自动转化。
threenewbee 2018-03-20
  • 打赏
  • 举报
回复
没看明白,你是希望这样还是不希望这样
  • 打赏
  • 举报
回复
msdn 如下: R 或 r 往返过程 只有 Single 和 Double 类型支持此格式。往返过程说明符保证转换为字符串的数值再次被分析为相同的数值。使用此说明符格式化数值时,首先使用常规格式对其进行测试:Double 使用 15 位精度,Single 使用 7 位精度。如果此值被成功地分析回相同的数值,则使用常规格式说明符对其进行格式化。但是,如果此值未被成功地分析为相同数值,则它这样格式化:Double 使用 17 位精度,Single 使用 9 位精度。 虽然此处可以存在精度说明符,但它将被忽略。使用此说明符时,往返过程优先于精度。
  • 打赏
  • 举报
回复
那叫做字符串格式化,double 本身哪里有什么“科学记数法”?
AnyJie 2018-03-20
  • 打赏
  • 举报
回复
微软默认转成了科学记数法,可以写个方法不去转。
xuzuning 2016-10-11
  • 打赏
  • 举报
回复
实测证明你说的是错的,4 个数都是用科学计数法显示的
smypolice 2016-10-11
  • 打赏
  • 举报
回复
就是这一个数值的问题,还是某一类数值都会出现这种问题?
zidianren11 2016-10-11
  • 打赏
  • 举报
回复
之前描述有点问题,以50000022001200047为例,将其直接赋值给某个double类型的变量,这个变量显示的值为50000022001200048.0。看截图 再以50000000000000000为例最终显示的是科学计数。 不知道什么原因。
没法下载,到这里折腾一把试试。 本文由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,536

社区成员

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

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

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