CRC校验程序设计要求 1、校验多项式采用:CRC-16; 2、输入数据流不定长,输入数据流放入txt文件中;输出存入到同一文件的下一行,后面2字节为校验码,采用小端格式; 3、画出程序流程图; 4、计算0x00-0xff的CRC校验码表;c语言实现

时间: 2024-05-16 07:13:57 浏览: 18
以下一个CRC校验程序的C语言实现,采用CRC-16校验多项式,输入数据流从txt文件中读入,输出存入到同一文件的下一行,后面2字节为校验码,采用小端格式。 程序流程图可以根据以下代码自行绘制: ```c #include <stdio.h> #include <stdlib.h> #define CRC16_POLY 0x8005 // CRC-16多项式 // 计算CRC-16校验码表 void crc16_table(unsigned short *table) { int i, j; unsigned short crc; for (i = 0; i < 256; i++) { crc = i << 8; for (j = 0; j < 8; j++) { if (crc & 0x8000) { crc = (crc << 1) ^ CRC16_POLY; } else { crc <<= 1; } } table[i] = crc; } } // 计算CRC-16校验码 unsigned short crc16(unsigned char *data, int len, unsigned short *table) { int i; unsigned short crc = 0xFFFF; for (i = 0; i < len; i++) { crc = (crc << 8) ^ table[((crc >> 8) ^ data[i]) & 0xFF]; } return crc; } int main() { FILE *fp_in, *fp_out; unsigned char *data; unsigned short *table; unsigned short crc; int len, i; // 打开输入文件 fp_in = fopen("input.txt", "rb"); if (fp_in == NULL) { printf("Error opening input file.\n"); return 1; } // 打开输出文件 fp_out = fopen("output.txt", "ab"); if (fp_out == NULL) { printf("Error opening output file.\n"); return 1; } // 计算CRC-16校验码表 table = (unsigned short *)malloc(sizeof(unsigned short) * 256); crc16_table(table); // 读入数据流并计算CRC-16校验码 while (!feof(fp_in)) { // 读入数据流 data = (unsigned char *)malloc(sizeof(unsigned char) * 1024); len = fread(data, 1, 1024, fp_in); // 计算CRC-16校验码 crc = crc16(data, len, table); // 输出数据流和CRC-16校验码 fwrite(data, 1, len, fp_out); fwrite(&crc, 1, 2, fp_out); free(data); } free(table); fclose(fp_in); fclose(fp_out); return 0; } ```

相关推荐

最新推荐

recommend-type

CRC-8校验方法 doc

根据信息码和CRC码之间所遵循的规则(即与发送时生成CRC校验码相同的规则)进行检验,校验采用计算机的模二除法,即除数和被除数(即生成多项式)做异或运算,进行异或运算时除数和被除数最高位对齐,进行按位异或...
recommend-type

Java中循环冗余校验(CRC32)的实现

CRC校验实用程序库在数据存储和数据通讯领域,为了保证数据的正确,就不得不采用检错的手段,下面这篇文章主要给大家介绍了关于Java中循环冗余校验(CRC32)实现的相关资料,需要的朋友可以参考借鉴,下面来一起看看...
recommend-type

数据结构实验报告之一元多项式求和(链表)报告2.doc

实验内容:一元多项式求和。 把任意给定的两个一元多项式P(x) ,Q(x) 输入计算机,计算它们的和并输出计算结果。 实验内容: 1.问题描述: 一元多项式求和——把任意给定的两个一元多项式P(x) ,Q(x) 输入计算机,...
recommend-type

C语言:一元多项式加减法运算(链表 附答案).docx

C语言链表的入门题,里面提供了两种思路供参考,用链表来实现一元多项式的加减法,并按照一定规律输出。也是练习链表和排序算法的一道小实验,初学链表的小伙伴可以参考参考噢
recommend-type

用模2除法计算CRC码的CRC校验软件设计

1、环境要求:Windows2000/XP/7;C;信息交换内容为文本文件;信息交换方式为共享文件 2、编码要求:生成多项式为CRC-32 3、功能要求:能在两台计算机机上运行程序,一台产生CRC码,另一台校验
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

HSV转为RGB的计算公式

HSV (Hue, Saturation, Value) 和 RGB (Red, Green, Blue) 是两种表示颜色的方式。下面是将 HSV 转换为 RGB 的计算公式: 1. 将 HSV 中的 S 和 V 值除以 100,得到范围在 0~1 之间的值。 2. 计算色相 H 在 RGB 中的值。如果 H 的范围在 0~60 或者 300~360 之间,则 R = V,G = (H/60)×V,B = 0。如果 H 的范围在 60~120 之间,则 R = ((120-H)/60)×V,G = V,B = 0。如果 H 的范围在 120~180 之间,则 R = 0,G = V,B =
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。