C++的double类型是用64位二进制数存储的,对于一个double类型的数,机器先将该数转换为二进制数,然后进行规格化处理,将小数点移到最左边的1后面,计算小数点的移位数N,阶码就是N+1023,1023(十进制)-3FFh(十六进制)--(1111111111)(二进制)10个1,然后用52位存储规格化后的小数点后面的52位二进制数。符号位根据正负设置。
如:double a=12345.67891023456;
123456.67891023456转化为二进数是11000000111001.101011011100110100001111101001100101101,规格化处理,小数点要移13位,阶码是13+1023,用11位二进制数表示为 “10000001100”,保存小数点后的52位二进制数,那么机器码就是 0 - 10000001100 - 1000000111001101011011100110100001111101001100101101
符号位 阶码 尾数
从新转化为十进制数,先将1.1000000111001101011011100110100001111101001100101101转为十进制数1.507040882596992,阶码减回1023得13,
1.507040882596992 * 2 ^13=12345.67891023456;