RS232/485通信方式

数据以RS232/485方式通信时,以0xA5作为开始码,以0xAE作为结束码。在开始码和结束码之间的0xA5, 0xAA, 0xAE数据需要进行转码。

PC端发送数据时将1个码变为2个码:

0xA5 -> 0xAA 0x05

0xAA -> 0xAA 0x0A

0xAE -> 0xAA 0x0E

PC端接收数据时将2个码变为1个码:

0xAA 0x05 -> 0xA5

0xAA 0x0A -> 0xAA

0xAA 0xAE -> 0xAE

如:

int CRs232::SendData(const BYTE *pBuffer, int nLength)
{
int i;
BYTE *pTemp;
BYTE szTemp[4096];

pTemp = szTemp;
*pTemp++ = 0xA5;
for(i=0; i<nLength; i++)
{
if(*pBuffer == 0xA5 || *pBuffer == 0xAA || *pBuffer == 0xAE)
{
*pTemp++ = 0xAA;
*pTemp++ = (BYTE)(*pBuffer & 0x0f);
}
else
{
*pTemp++ = *pBuffer;
}
pBuffer++;
}
*pTemp++ = 0xAE;

i = (int)(pTemp - szTemp);
return WriteData(szTemp, i);
}

//////////////////////////////////////////////////////////////////////////////////////////////////////////////

///////////////////////////////////////////////////////////////////////////////////////////////////////////

int CRs232::ReceiveData(BYTE *pBuffer, int nBufSize)
{
int nRead;
int nLength;
int i, rep;
int cv;
BYTE ch;
BYTE szTemp[4096];
bool bRecvStarted;

#ifdef _DEBUG//测试缓冲区溢出
//BYTE buffer[ 5 ];
//pBuffer = buffer;
//nBufSize = sizeof( buffer );
#endif

cv = 0;
nLength = 0;
bRecvStarted = false;
for( rep = 1; rep > 0; )
{
nRead = ReadData( szTemp, sizeof( szTemp ) );
if( nRead > 0 )
{
for( i = 0; i < nRead; i++ )
{
ch = szTemp[ i ];
if( ch == 0xA5 )//开始接受数据
{
cv = 0;
nLength = 0;
bRecvStarted = true;
}
else if( ch == 0xAE )//结束接受数据
{
cv = 0;
rep = -1; //设置成功接受数据标记
bRecvStarted = false;
break;
}
else if( ch == 0xAA )//设置转码标记
{
cv = 1;
}
else if( nLength < nBufSize )
{
if( bRecvStarted )//已开始接受数据
{
if( cv )//需要转码
{
cv = 0;
pBuffer[ nLength++ ] = 0xA0 | ( 0x0F & ch );
}
else//不需转码
{
pBuffer[ nLength++ ] = ch;
}
}
}
else//缓冲区溢出
{
rep = 0; //设置主循环退出条件
break; //退出此内循环
}
}
}
else//接受不到数据,
{
rep = 0;//设置主循环退出条件
}
}
if( rep == -1 )//接受完整数据成功
{
return nLength;
}
else
{
return 0;
}
}

RS232/485通信方式 保存和加载时数据的处理的更多相关文章

  1. TensorFlow模型保存和加载方法

    TensorFlow模型保存和加载方法 模型保存 import tensorflow as tf w1 = tf.Variable(tf.constant(2.0, shape=[1]), name= ...

  2. keras中的模型保存和加载

    tensorflow中的模型常常是protobuf格式,这种格式既可以是二进制也可以是文本.keras模型保存和加载与tensorflow不同,keras中的模型保存和加载往往是保存成hdf5格式. ...

  3. 背水一战 Windows 10 (62) - 控件(媒体类): InkCanvas 保存和加载, 手写识别

    [源码下载] 背水一战 Windows 10 (62) - 控件(媒体类): InkCanvas 保存和加载, 手写识别 作者:webabcd 介绍背水一战 Windows 10 之 控件(媒体类) ...

  4. 完美实现保存和加载easyui datagrid自定义调整列宽位置隐藏属性功能

    需求&场景 例表查询是业务系统中使用最多也是最基础功能,但也是调整最平凡,不同的用户对数据的要求也不一样,所以在系统正式使用后,做为开发恨不得坐在业务边上,根据他们的要求进行调整,需要调整最多 ...

  5. 从头学pytorch(十二):模型保存和加载

    模型读取和存储 总结下来,就是几个函数 torch.load()/torch.save() 通过python的pickle完成序列化与反序列化.完成内存<-->磁盘转换. Module.s ...

  6. 使用Pytorch在多GPU下保存和加载训练模型参数遇到的问题

    最近使用Pytorch在学习一个深度学习项目,在模型保存和加载过程中遇到了问题,最终通过在网卡查找资料得已解决,故以此记之,以备忘却. 首先,是在使用多GPU进行模型训练的过程中,在保存模型参数时,应 ...

  7. 超详细的Tensorflow模型的保存和加载(理论与实战详解)

    1.Tensorflow的模型到底是什么样的? Tensorflow模型主要包含网络的设计(图)和训练好的各参数的值等.所以,Tensorflow模型有两个主要的文件: a) Meta graph: ...

  8. MSIL实用指南-局部变量的声明、保存和加载

    这一篇讲解方法内的局部变量是怎么声明.怎样保存.怎样加载的. 声明局部变量声明用ILGenerator的DeclareLocal方法,参数是局部变量的数据类型,得到一个局部变量对应的创建类LocalB ...

  9. tensorflow模型持久化保存和加载

    模型文件的保存 tensorflow将模型保持到本地会生成4个文件: meta文件:保存了网络的图结构,包含变量.op.集合等信息 ckpt文件: 二进制文件,保存了网络中所有权重.偏置等变量数值,分 ...

随机推荐

  1. 关于URL优化的一些经验

    URL在搜索结果列表中时显示内容之一.设计网站结构时需要对目录及文件命名系统做事先规划.总的原则是首先从用户体验出发,URL应该清晰友好.方便记忆,然后才考虑URL对排名的影响.具体可以考虑以下几个方 ...

  2. 数据库之 MySQL --- 视图的原理解析与创建(八)

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 1.什么是视图? 视图:MySQL从5.0.1版本开始提供视图功能.一种虚拟存在的表,行和列的数据来自定 ...

  3. Java实现 LeetCode 714 买卖股票的最佳时机含手续费(动态规划 || 迭代法)

    714. 买卖股票的最佳时机含手续费 给定一个整数数组 prices,其中第 i 个元素代表了第 i 天的股票价格 :非负整数 fee 代表了交易股票的手续费用. 你可以无限次地完成交易,但是你每次交 ...

  4. Java实现 LeetCode 301 删除无效的括号

    301. 删除无效的括号 删除最小数量的无效括号,使得输入的字符串有效,返回所有可能的结果. 说明: 输入可能包含了除 ( 和 ) 以外的字符. 示例 1: 输入: "()())()&quo ...

  5. Java实现 LeetCode 290 单词规律

    290. 单词规律 给定一种规律 pattern 和一个字符串 str ,判断 str 是否遵循相同的规律. 这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非 ...

  6. Java实现 LeetCode 202 快乐数

    202. 快乐数 编写一个算法来判断一个数是不是"快乐数". 一个"快乐数"定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和,然后重复这个过 ...

  7. Java实现 LeetCode 116 填充每个节点的下一个右侧节点指针

    116. 填充每个节点的下一个右侧节点指针 给定一个完美二叉树,其所有叶子节点都在同一层,每个父节点都有两个子节点.二叉树定义如下: struct Node { int val; Node *left ...

  8. 数据结构&算法

    20个最常用.最基础数据结构与算法: 10个数据结构:数组.链表.栈.队列.散列表.二叉树.堆.跳表.图.Trie 树. 10个 算法      :递归.排序.二分查找.搜索.哈希.贪心.分治.回溯. ...

  9. 调用webservice接口,报错:(十六进制值0x01)是无效的字符

    #事故现场 调用webservice接口,报错:(十六进制值0x01)是无效的字符. 如图: 意思是webservice返回的信息中包含无效的字符,无法解析成xml: #分析 使用postman向we ...

  10. [AGC034F]RNG and XOR

    题目   点这里看题目. 分析   第一步可以将\(A\)数组转化成概率\(P(j)\):每一步操作异或\(j\)的概率.   接着发现,\(x\)从\(0\)变成\(i\)的期望等于\(x\)从\( ...