当前位置:首页 > 原创 > 振南技术干货集(风云录)
[导读]很多人不能很好的使用和处理浮点,其主要根源在于对它的表达与存储方式不是很理解。最典型的例子就是经常有人问我:“如何使用串口来发送一个浮点数?”

关于浮点数的传输

很多人不能很好的使用和处理浮点,其主要根源在于对它的表达与存储方式不是很理解。最典型的例子就是经常有人问我:“如何使用串口来发送一个浮点数?”

我们知道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 浮点变量数值的计算方法

所以,正确的发送浮点数的方法是这样的:

接收者将数据还原为浮点:

其实我们应该发现数据类型的实质:不论是什么数据类型,它的基本组成无非就是内存中存储的若干个字节。只是我们人为的赋予了这些字节特定的编码方式或数值表达。看穿了这些,我们就认识到了数据的本质了,我们甚至可以直接操作数据。

声明:该篇文章为本站原创,未经授权不予转载,侵权必究。
换一批
延伸阅读

memcpy函数的功能是用来作内存搬运,就是将数据从一个数组赋值到另一个数组。它的实现很简单:

关键字: memcpy C 语言 串化

初学C语言的时候,有一个小编程题我们应该都记得,就是变量互换。

关键字: 变量互换 sizeof C 语言

我给大家出一道有意思的题目:如何快速得到一个字节的位逆序字节。比如0X33的位逆序字节是0XCC。

关键字: 字节 C 语言 volatile

补码是一个很基础的概念,但是对于很多人来说,其实有些迷糊,这里对补码进行一些通俗而深刻的讲解。

关键字: C 语言 补码 CPU

另外,有时候优先级还与C语言编译器有关,同一个表达式在不同的平台上,可能表达的意义是不同的。所以,为了代码的可植移性、正确性以及可读性,振南强烈建议多用一些()。

关键字: C 语言 编程语言 赋值操作

我们本希望循环5次,然后结束,但是实际情况是陷入了死循环。这种错误在实际开发中,还比较难发现。其原因在于i的类型,无符号整型是永远不小于0的。我们需要将i的类型改为有符号型。

关键字: 死循环 C 语言 空循环

以上的例子可能有些鸡肋,“一个if能搞定的事情,我为什么要用for?”,没错。我们这里主要是为了解释for循环的灵活用法。深入理解了它的本质,有助于我们在实际开发中让工作事半功倍,以及看懂别人的代码。

关键字: for循环 C 语言

直接操作数据?我们来举个例子:取一个整型数的相反数。一般的实现方法是这样的:

关键字: 数据 浮点 C 语言

C语言中要表达一个字节数据序列(内存中连续存储的若干个字节),我们可以使用字节数组,如unsigned char array[10]={0,1,2,3,4,5,6,7,8,9}。其实字符串,本质上也是一个字节序列,但是通...

关键字: 转义符 字符串常量 C 语言

字符串是C语言中最基础的概念,也是最常被用到的。在嵌入式开发中,我们经常要将一些字符串通过串口显示到串口助手或调试终端上,作为信息提示,以便让我们了解程序的运行情况;或者是将一些常量的值转为字符串,来显示到液晶等显示设备...

关键字: 字符串 指针 C 语言
关闭