两者的主要区别如下:
1、在内存中占有的字节数不同:
单精度浮点数在机内存占4个字节,双精度浮点数在机内存占8个字节。
2、有效数字位数不同:
单精度浮点数有效数字8位,双精度浮点数有效数字16位。
3、数值取值范围:
单精度浮点数的表示范围: -3.40E+38~3.40E+38,双精度浮点数的表示范围: -1.79E+ 308~-1.79E+308。
4、在程中处理速度不同:
一般来说, CPU处理单精度浮点数的速度比处理双精度浮点数快,如果不声明,默认小数为double类型,所以如果要用float的话,必须进行强转。
参考资料来源:百度百科-double
参考资料来源:百度百科-float
对编程人员来说,double 和 float 的区别是double精度高,有效数字16位,float精度7位。但double消耗内存是float的两倍,double的运算速度比float慢得多,C语言中数学函数名称double 和 float不同,不要写错,能用单精度时不要用双精度(以省内存,加快运算速度)。
扩展资料
double(双精度浮点型)是计算机使用的一种资料型别。比起单精度浮点数(float),double(双精度浮点数)使用 64 位(8字节) 来储存一个浮点数。 它可以表示十进制的15或16位有效数字,负值取值范围为 -1.7976E+308 到 -4.94065645841246544E-324,正值取值范围为 4.94065645841246544E-324 到 1.797693E+308
浮点型数据类型,FLOAT 数据类型用于存储单精度浮点数或双精度浮点数。浮点数使用 IEEE(电气和电子工程师协会)格式。浮点类型的单精度值具有 4 个字节,包括一个符号位、一个 8 位 excess-127 二进制指数和一个 23 位尾数。
尾数表示一个介于 1.0 和 2.0 之间的数。由于尾数的高顺序位始终为 1,因此它不是以数字形式存储的。此表示形式为 float 类型提供了一个大约在 -3.4E+38 和 3.4E+38 之间的范围。
参考资料
但是来年各个的精度和范围不一样罢了
double有8个字节
float只有4个字节
double表示的范围比float大 而且 一般在程序里面都用double
错误少 而double在精度运算时 会出现错误 有误差
[1]区别一
Double要有using System;
或System.Double
后才能用
[2]区别二
double是保留字,Double不是.
[3]区别三
Double是CTS类型
double是C#类型
综上所述,
只有语法上的区别,
没有内容上的区别.