关于校验码的算法

最近工作遇到和校验码打交道的地方,很多地方都会生成校验码.校验码的计算方法也是多种多样的,但是根本不离其宗.

这里我们介绍几种常用的校验码.

1.异或校验码.

听名字就会知道,需要做异或运算.XOR算法,这个是按照字符做异或运算,最终得到一个异或校验码.

异或,相同为0,不相同位1,下面这个算法就是异或之后输出结果我们用int型输出数据.

void XOR(char* p,int nsize,int &x)

{

复制代码
for(int i=0;i<nsize;i++)
{
	if(i==0)
	{	x =p[i];
	}
	else
	{
		x^=p[i];
	}

}

}

2.和校验

.算法上就是求和,我们把上面的算法稍微修改一下就是求和,把异或运算改成求和运算就好了.

void XOR(char* p,int nsize,int &x)

{

复制代码
for(int i=0;i<nsize;i++)
{
	if(i==0)
	{	x =p[i];
	}
	else
	{
		x+=p[i];
	}

}

}

3.CRC16 校验,这种都需要根据说明资料按照要求计算就好了.

校验码说简单也简单,说复杂也是复杂,关键是看你怎么使用,目前我们常见的就是异或和求和计算校验码.

仅记录工作中的小知识点.!!!

相关推荐
望未来无悔39 分钟前
系统学习算法 专题十八 队列+宽搜
java·算法
Dovis(誓平步青云)41 分钟前
《探索C++11:现代语法的性能优化策略(中篇)》
开发语言·c++
xz2024102****41 分钟前
最大似然估计:损失函数的底层数学原理
人工智能·算法·机器学习·概率论
一个响当当的名号1 小时前
c++primer 个人学习总结-模板和泛型编程
开发语言·c++·学习
落羽的落羽1 小时前
【C++】C++11的可变参数模板、emplace接口、类的新功能
开发语言·c++·学习
Xの哲學1 小时前
Linux RCU (Read-Copy-Update) 机制深度分析
linux·网络·算法·架构·边缘计算
数模加油站1 小时前
25高教社杯数模国赛【C题国一学长思路+问题分析】第二弹
算法·数学建模·数模国赛·高教社杯全国大学生数学建模竞赛
小跌—2 小时前
Linux:进程信号理解
linux·c++·算法
liulilittle2 小时前
HTTP简易客户端实现
开发语言·网络·c++·网络协议·http·编程语言
微风扬!2 小时前
C++ Lambda 表达式完整指南
c++·lambda