模拟串口数据传递
(参考了一些网友的思路,在此表示感谢~)
需要注意的是:
对于无符号数来说,左移和右移都是用的逻辑移位,即左移低位空出的补0,右移高位空出的补0;
对于有符号数来说,用的是算术移位,左移多出的会移进符号位,右移在gcc编译器下是算术右移,即空出的高位补符号位。
详细可参考此处:C语言 有符号数和无符号数的移位运算
#include<stdio.h>
typedef unsigned char uint8;
typedef unsigned int uint32;
int main(void)
{
uint32 num1 = 12345678,num2;
int num3 = -12345678,num4;
float num5 = -1234.567,num6;
uint8 TxBuf1[4];
char TxBuf2[4];
int i;
//------------------------------------------------ 串口发送无符号整数
TxBuf1[0] = num1;
TxBuf1[1] = num1 >> 8;
TxBuf1[2] = num1 >> 16;
TxBuf1[3] = num1 >> 24;
num2 = ((uint32)TxBuf1[0] | (uint32)TxBuf1[1]<<8 | (uint32)TxBuf1[2]<<16 | (uint32)TxBuf1[3]<<24); //数据整合
printf("num2 = %d\n",num2);
//-------------------------------------------------- 串口发送有符号整数
TxBuf2[0] = *((int *)&num3);
TxBuf2[1] = *((int *)&num3) >> 8;
TxBuf2[2] = *((int *)&num3) >> 16;
TxBuf2[3] = *((int *)&num3) >> 24;
num4 = *((int *)TxBuf2);
printf("num4 = %d\n",num4);
//------------------------------------------------ 串口发送浮点数
TxBuf2[0] = *((int *)&num5);
TxBuf2[1] = *((int *)&num5) >> 8;
TxBuf2[2] = *((int *)&num5) >> 16;
TxBuf2[3] = *((int *)&num5) >> 24;
num6 = *((float *)TxBuf2);
printf("num6 = %f\n",num6);
//------------------------------------------------ 串口发送浮点数
char *p = (char *)&num5;
for(i = 0;i < sizeof(float);i++)
TxBuf2[i] = *p++;
num6 = *((float *)TxBuf2);
printf("num6 = %f\n",num6);
return 0;
}
运行结果:
且慢,还有更好的方法!
typedef union
{
float value; //使用其他数据类型,修改此处并在下一行设置相应的字节数即可
unsigned char data[4];
}U_FloatData;
U_FloatData Uart_Send;
Uart_Send.value = 12.34;
for(i=0;i < 4;i++)
{
TXBuff[i] = Uart_Send.data[i];
}
最后将4个字节的 TX_Buff 数组发送即可。
版权声明:本文为jack__linux原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。