写一个C语言的程序设计,要求是进行CRC校验,校验多项式采用CRC-16,输入的数据不定长,输入数据流放入TXT文件中,输出放在同一文件的最后一行,输入数据中最后2个字节为校验码,采用小端格式,要求可以计算0x00~0xff的CRC校验码表

时间: 2024-05-02 15:23:29 浏览: 14
以下是一个实现CRC-16校验的C语言程序设计: ```c #include <stdio.h> #include <stdlib.h> #define CRC16_POLY 0xA001 // CRC-16多项式 #define BUF_SIZE 1024 // 缓冲区大小 // 生成CRC校验码表 void generate_crc_table(unsigned short crc_table[]) { unsigned short crc; int i, j; for (i = 0; i < 256; i++) { crc = i; for (j = 0; j < 8; j++) { if (crc & 0x0001) { crc = (crc >> 1) ^ CRC16_POLY; } else { crc >>= 1; } } crc_table[i] = crc; } } // 计算CRC校验码 unsigned short calc_crc(unsigned short crc_table[], unsigned char *data, int len) { unsigned short crc = 0; int i; for (i = 0; i < len; i++) { crc = (crc >> 8) ^ crc_table[(crc & 0xFF) ^ data[i]]; } return crc; } int main() { unsigned short crc_table[256]; char *filename = "data.txt"; FILE *fp = fopen(filename, "rb"); if (!fp) { printf("Failed to open file %s\n", filename); return 1; } // 生成CRC校验码表 generate_crc_table(crc_table); // 读取文件内容 unsigned char buf[BUF_SIZE]; int len = 0, total_len = 0; while ((len = fread(buf, 1, BUF_SIZE, fp)) > 0) { total_len += len; } fclose(fp); // 计算CRC校验码 unsigned short crc = calc_crc(crc_table, buf, total_len - 2); // 将CRC校验码写入文件末尾 fp = fopen(filename, "ab"); if (!fp) { printf("Failed to open file %s\n", filename); return 1; } fwrite(&crc, 2, 1, fp); fclose(fp); return 0; } ``` 该程序首先生成CRC-16校验码表,然后读取文件内容并计算CRC校验码,最后将校验码写入文件末尾。在计算CRC校验码时,程序会将最后两个字节忽略,因为这两个字节是校验码本身。在写入校验码时,程序采用了"ab"模式打开文件以追加方式写入数据。 注意,程序中用到的CRC-16多项式为0xA001,这是一种常用的CRC-16多项式。如果需要使用其他的CRC-16多项式,可以将该多项式替换为其他多项式。

相关推荐

最新推荐

recommend-type

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

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

一元多项式的计算--数据结构课程设计报告

一元多项式的计算--数据结构课程设计报告 大学的课程设计 共享 请多提宝贵意见
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

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

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