《 C 语言的一些“骚操作”及其深层理解》之关于浮点数的传输
扫描二维码
随时随地手机看文章
关于浮点数的传输
很多人不能很好的使用和处理浮点,其主要根源在于对它的表达与存储方式不是很理解。最典型的例子就是经常有人问我:“如何使用串口来发送一个浮点数?”
我们知道C语言中有很多数据类型,其中unsigned char、unsigned short、unsigned int、unsigned long我们称其为整型,顾名思义它们可以表达整型数。而能够表达的数值范围与数据类型所占用的字节数有关。数值的表达方法比如简单,如下图所示。
图2.4 整型变量数值的计算方法
一个字节可以表达0~255,两个字节(unsigned short)自然就可以表达0~65535,依次类推。
当需要把一个整型数值发送出去的时候,我们可以这样作:
也就是将构成整型的若干字节顺序发送即可。当然接收方一定要知道如何还原数据,也就是说它要知道自己接收到的若干字节拼在一起是什么类型,这是由具体通信协议来保障的。
OK,关于整型比较容易理解。但是换成float,很多人就有些迷糊了。因为float的数值表达方式有些复杂。有些人使用下面的方法来进行浮点的发送。
很显然这种方法非常的“业余”。还有人问我:“浮点小数字前后的数字可以发送,但是小数点怎么发?”这赤裸裸的体现了他对浮点类型的误解。
不要被float数值的表象迷惑,它实质上只不过是4个字节而已,如图2.5所示。
图2.5 浮点变量数值的计算方法
所以,正确的发送浮点数的方法是这样的:
接收者将数据还原为浮点:
其实我们应该发现数据类型的实质:不论是什么数据类型,它的基本组成无非就是内存中存储的若干个字节。只是我们人为的赋予了这些字节特定的编码方式或数值表达。看穿了这些,我们就认识到了数据的本质了,我们甚至可以直接操作数据。