码迷,mamicode.com
首页 > 编程语言 > 详细

串口常用校验算法(累加和、异或和)

时间:2018-12-11 12:48:15      阅读:359      评论:0      收藏:0      [点我收藏+]

标签:style   位置   算法   成功   last   xor   保留   color   end   

1、异或和

  异或和就是对数据逐一异或计算(异或结果与下一个数据异或)

  下面是校验实例

local rdbuf = "FFFF28000000000000600001000D0000000000000000000000000000000000000000000000000000000096"        
local fast = string.sub(rdbuf, 5, string.len(rdbuf)-2)
local last = string.sub(rdbuf, string.len(rdbuf)-1, string.len(rdbuf))
local num = bit.bxor(tonumber(string.sub(fast, 1, 2), 16), tonumber(string.sub(fast, 3, 4), 16)) --异或
local length = string.len(fast) - 1
for i = 5, length, 2 do
      num = bit.bxor(num, tonumber(string.sub(fast, i, i+1), 16))   
end 
if num == tonumber(last, 16) then
校验成功
end

2、累加和

  累加和也是逐一累加,但是计算不进位,所以最终结果其实是累加结果求256的余数

  下面是计算实例

local cmd = 10
cmd = string.format("%02X",cmd) -- 02X 是为了保留两位,空位置0   例如(A是0A)
local fast = "18000000000000600001000200".. cmd .."00000000000000010006"
local length = #fast - 1  
local num = 0
for i = 1, length, 2 do
    num = num + tonumber(string.sub(fast, i, i+1), 16)  
end 
num = num % 256
num = string.format("%02X",num)
local instruction = "FFFF" .. fast .. num

print(instruction)

 

串口常用校验算法(累加和、异或和)

标签:style   位置   算法   成功   last   xor   保留   color   end   

原文地址:https://www.cnblogs.com/liuguan/p/10101193.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!