'float' vs. 'double' precision

后端 未结 6 691
情话喂你
情话喂你 2020-11-22 14:56

The code

float x  = 3.141592653589793238;
double z = 3.141592653589793238;
printf(\"x=%f\\n\", x);
printf(\"z=%f\\n\", z);
printf(\"x=%20.18f\\n\", x);
print         


        
6条回答
  •  太阳男子
    2020-11-22 15:19

    Do doubles always have 16 significant figures while floats always have 7 significant figures?

    No. Doubles always have 53 significant bits and floats always have 24 significant bits (except for denormals, infinities, and NaN values, but those are subjects for a different question). These are binary formats, and you can only speak clearly about the precision of their representations in terms of binary digits (bits).

    This is analogous to the question of how many digits can be stored in a binary integer: an unsigned 32 bit integer can store integers with up to 32 bits, which doesn't precisely map to any number of decimal digits: all integers of up to 9 decimal digits can be stored, but a lot of 10-digit numbers can be stored as well.

    Why don't doubles have 14 significant figures?

    The encoding of a double uses 64 bits (1 bit for the sign, 11 bits for the exponent, 52 explicit significant bits and one implicit bit), which is double the number of bits used to represent a float (32 bits).

提交回复
热议问题