输出结果:
我们先来看个实例:
double number2 = 1.11111111111111111111; float number3 = (float) 1.11111111111111111111; Console.WriteLine(number2); Console.WriteLine(number3); Console.ReadKey();输出结果:
根据double和float的取值范围:
double64 位双精度浮点型(+/-)5.0 x 10^-324 到 (+/-)1.7 x 10^308float32 位单精度浮点型-3.4 x 10^38 到 + 3.4 x 10^38
它们用图表示就是这样的:
double比float的表示范围更大
问题1:给两个变量赋值的时候不是明明有很长的一大串数字吗?为什么输出的结果却只有这几位呢?
问题2:声明的number3是单精度浮点型数据,为什么后面赋值的时候还要写(float)呢?它的作用是什么?不要不行吗?
问题1:
通过声明时的代码和输出的结果我们可以发现:
给声明的double类型的number2变量赋值时,小数点后有20位数,输出的结果却只有16位数
给声明的float类型的number3变量赋值时,小数点后有20位数,输出的结果却只有7位数
实际上,在C#中,
double为双精度,在计算机内是占8个字节的,有效位数为16位folat为单精度,在计算机内是占4个字节,有效位数是7位decimal为高精度,有效位数是28位
问题2:
我们来看一下在VS2019中,代码是什么样的
系统会报一个红色的错误提示:“无法将Double类型隐式转换为“float”类型;请使用“F”后缀创建此类型。
说的是什么意思呢?
在C#中,
当声明精度型的变量时,系统会自动默认这个小数为double类型的数值,所以在上图中我们声明的这个number3变量现在看着是float数据类型的数值,但实际上它是一个double类型的数值,要想将这个double类型转换为float类型,就需要在这个float数值的后面加上“F”或在小数前面加上(float)。如下图
float number3 = (float)1.11111111111111111111;
float number3 = 1.11111111111111111111F;
总结
在C#中,double比float的表示范围更大;
decimal的有效位数比double、float类型的都大,但表示范围却比它们两个都小;
decimal适用于银行这种更精确的货币,可以精确分数;
当声明小数的精度类型数值时,系统会自动默认为double类型;
声明float类型数值时,需要在小数前面加(float)或在小数后面加F