基于查表法的 CRC8 / CRC16 / CRC32校驗解析

在嵌入式開發中,CRC(Cyclic Redundancy Check)循環冗余校驗算法廣泛應用于通信數據校驗、Flash 數據完整性檢測、Bootloader 升級驗證等場景。本文將深入剖析一套完整的 CRC8、CRC16 和 CRC32 實現,并通過查表法(Table Lookup Method)提升運算效率。

一、CRC 原理簡述

CRC 的基本思想是:將要校驗的數據視為一個長二進制串,并與某一指定的“生成多項式”進行二進制模2除法,所得余數即為 CRC 校驗值。

  • CRC8 常用多項式:x^8 + x^2 + x + 1(即 0x07)

  • CRC16 常用多項式:x^16 + x^15 + x^2 + 1(即 0x8005 或 0x1021)

  • CRC32 常用多項式:x32 + x2? + x23 + ... + x + 1(IEEE 802.3 標準)

二、查表法

在計算 CRC 的過程中,每處理一個字節都涉及到按位移位與異或操作,效率較低。而查表法則是將所有可能的單字節計算結果預先計算出來存入查找表(Lookup Table),運行時每次只需一次查表和一次異或操作即可,大幅提升 CRC 運算效率,非常適合資源受限的嵌入式系統。

查找表生成原理: 以 CRC8 為例,查找表中每個表項表示某一字節初值經過 CRC 算法后所得的中間 CRC 值。我們可以預先對 0x00 ~ 0xFF 的每個字節進行模擬計算,生成 256 項查找表,運行時直接查詢即可。

查找表自動生成腳本
對于 CRC 表項,可以參考使用如下 Python 腳本快速生成:

def generate_crc8_table(poly=0x07):table = []for i in range(256):crc = ifor _ in range(8):crc = (crc << 1) ^ poly if (crc & 0x80) else (crc << 1)crc &= 0xFFtable.append(crc)return table

可以將生成結果格式化輸出為 C 語言數組,粘貼進工程中。

函數依賴預定義的查找表,如:

const uint8_t crc8_tab[256] = {0x00, 0x5E, 0xBC, ..., 0x53 // 共256項
};const uint16_t crc16_tab[256] = {0x0000, 0x1021, ..., 0x1EF0 // 共256項
};const uint32_t crc32_tab[256] = {0x00000000, 0x04C11DB7, ..., 0x2D02EF8D // 共256項
};

三、代碼實現詳解

1. CRC8 查表法實現

// 生成多項式:0x07,初始值:0x00,輸入不反轉,輸出不反轉
static const uint8_t crc8_table[256] = {// 表項略去,可通過代碼生成,見下文
};uint8_t crc8_calc(const uint8_t *data, uint32_t length) {uint8_t crc = 0x00;while (length--) {crc = crc8_table[crc ^ *data++];}return crc;
}

2. CRC16 查表法實現(以 CRC-16-IBM 為例)

// 生成多項式:0x8005,初始值:0x0000
static const uint16_t crc16_table[256] = {// 表項略,可使用工具或代碼生成
};uint16_t crc16_calc(const uint8_t *data, uint32_t length) {uint16_t crc = 0x0000;while (length--) {crc = (crc << 8) ^ crc16_table[((crc >> 8) ^ *data++) & 0xFF];}return crc;
}

3. CRC32 查表法實現(IEEE 標準)

static const uint32_t crc32_table[256] = {// 可使用 Python 腳本生成
};uint32_t crc32_calc(const uint8_t *data, uint32_t length) {uint32_t crc = 0xFFFFFFFF;while (length--) {crc = (crc >> 8) ^ crc32_table[(crc ^ *data++) & 0xFF];}return crc ^ 0xFFFFFFFF;
}

四、示例與應用建議

串口通信幀校驗

typedef struct {uint8_t header;uint8_t length;uint8_t payload[256];uint8_t crc8;
} uart_frame_t;// 接收處理時:
bool check_frame_crc(const uart_frame_t *frame) {uint8_t calc_crc = crc8_calc((uint8_t*)frame, sizeof(uart_frame_t) - 1);return calc_crc == frame->crc8;
}
  • Flash 校驗:通過 CRC 校驗 Flash 存儲的數據結構完整性。

  • Bootloader 驗證:用于 App 區固件完整性驗證,保障升級安全。

  • 通信協議校驗:如 CAN、UART、SPI 數據包尾部追加 CRC 字段,用于誤碼檢測。

  • 內存鏡像驗證:設備重啟后對 RAM 區數據校驗,判斷是否需要重新初始化。

查表法 CRC 是一種高效、實用的算法,在嵌入式通信、文件校驗、數據鏈路等場景中不可或缺。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/75580.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/75580.shtml
英文地址,請注明出處:http://en.pswp.cn/web/75580.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

二戰藍橋杯所感

&#x1f334; 前言 今天是2025年4月12日&#xff0c;第十六屆藍橋杯結束&#xff0c;作為二戰的老手&#xff0c;心中還是頗有不甘的。一方面&#xff0c;今年的題目比去年簡單很多&#xff0c;另一方面我感覺并沒有把能拿的分都拿到手&#xff0c;這是我覺得最遺憾的地方。不…

基于ueditor編輯器的功能開發之給編輯器圖片增加水印功能

用戶需求&#xff0c;雙擊編輯器中的圖片的時候&#xff0c;出現彈框&#xff0c;用戶可以選擇水印縮放倍數、距離以及水印所放置的方位&#xff08;當然有很多水印插件&#xff0c;位置大小透明度用戶都能夠自定義&#xff0c;但是用戶需求如此&#xff0c;就自己寫了&#xf…

算法題(123):回文日期

審題&#xff1a; 本題需要我們判斷以八位數確定的日期范圍中是否存在回文數 思路&#xff1a; 方法一&#xff1a;枚舉法 1.確定枚舉對象&#xff1a; 對象1&#xff1a;八位數日期&#xff0c;所需枚舉次數&#xff1a;10^8 對象2&#xff1a;年&#xff0c;所需枚舉次數&…

數據庫表的操作

一、數據庫的搭建 如上篇文章 二、基礎了解 show命令支持模糊匹配 show databases、show tables、 show databases like “” “%”、“_”通配符字符串 三、MySQL數據庫表的操作 關系型數據庫都是遵循SQL語法進行數據查詢和管理的 3.1 SQL介紹 3.1.1 SQL的功能 結構化查詢語…

在 Lua 中實現 JSON 與 Table 的相互轉換的詳細使用方法

在 Lua 中實現 JSON 與 Table 的相互轉換是常見的數據序列化需求。以下是詳細的實現方案、性能優化技巧及進階用法&#xff1a; 在 Lua 中實現 JSON 與 Table 的相互轉換的詳細使用方法-目錄 一、常用 JSON 庫對比二、基礎轉換實現1. 使用 lua-cjson&#xff08;高性能 C 庫&am…

dbVisitor 規則怎么用?

在數據庫操作中&#xff0c;dbVisitor 是一個功能強大的工具&#xff0c;其規則的使用大大簡化了 SQL 語句的編寫過程。下面將詳細介紹 dbVisitor 規則的使用方法并附上具體例子。 一、規則的基本調用 在 dbVisitor 中&#xff0c;SQL 語句可以通過 {...} 的形式來調用規則&a…

Kingbase 常用運維命令總結

一、數據庫連接與基礎操作 連接指定服務器數據庫 ksql -h 主機IP -p 端口號 -U 用戶名 -d 數據庫名 -W # 示例&#xff1a;連接 IP 為 192.168.1.100 的數據庫 ksql -h 192.168.1.100 -p 54321 -U system -d test -W 斷開數據庫連接 \q 或 exit 查看數據庫列表及詳細信息…

【數據結構與算法】LRU Cache 算法實現

文章目錄 Ⅰ. 什么是 LRU CacheⅡ. LRU Cache 的實現[146. LRU 緩存](https://leetcode.cn/problems/lru-cache/) Ⅰ. 什么是 LRU Cache ? LRU&#xff08; Least Recently Used&#xff09; 是一種淘汰策略的縮寫&#xff0c;意思是 最近最少使用&#xff0c;它是一種 Cache…

網頁布局匯總

1. 盒模型 容器大小 內容大小 內邊距(padding) 邊框大小 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0">&l…

打造海外流量矩陣,TikTok云控工具讓獲客更簡單!

跨境獲客&#xff0c;始終是無數企業主心中的一道難題。今天&#xff0c;給大家帶來一款強大實用的工具——TikTok矩陣云控系統&#xff0c;幫你輕松突破流量瓶頸&#xff0c;實現高效跨境獲客&#xff01; 跨國遠程操控——蘋果手機矩陣云控系統 在正式開始之前&#xff0c;…

MyBatis-plus 快速入門

提示&#xff1a;MyBatis-Plus&#xff08;MP&#xff09;是一個 MyBatis的增強版 文章目錄 前言使用MybatisPlus的基本步驟1、引入MybatisPlus依賴代替Mybatis依賴2、定義Mapper接口并繼承BaseMapper他是怎么知道哪張表&#xff0c;哪些字段呢 3、實體類注解4、根據需要添加配…

找搭子系統 搭子經濟新風口 基于精準匹配的社交新生態探索

一、市場前景&#xff1a;為什么現在需要"找搭子"&#xff1f; 孤獨經濟爆發 超60%年輕人存在"精準陪伴"需求&#xff08;2024社交報告&#xff09; 傳統社交App無法滿足"非婚戀、非熟人"的中間態需求 線下活動復蘇 劇本殺/飛盤等興趣活動年增…

深入探析C#設計模式:訪問者模式(Visitor Pattern)的原理與應用

引言 在軟件開發中&#xff0c;設計模式為我們提供了高效、可維護的解決方案。而在眾多設計模式中&#xff0c;訪問者模式&#xff08;Visitor Pattern&#xff09;以其獨特的結構和應用場景&#xff0c;在復雜系統中發揮著重要作用。本文將深入講解訪問者模式的定義、原理、優…

Redis核心功能實現

前言 學習是個輸入的過程&#xff0c;在進行輸入之后再進行一些輸出&#xff0c;比如寫寫文章&#xff0c;筆記&#xff0c;或者做一些技術串講&#xff0c;雖然需要花費不少時間&#xff0c;但是好處很多&#xff0c;首先是能通過輸出給自己的輸入帶來一些動力&#xff0c;然…

RPA VS AI Agent

圖片來源網絡 RPA&#xff08;機器人流程自動化&#xff09;和AI Agent&#xff08;人工智能代理&#xff09;在自動化和智能化領域各自扮演著重要角色&#xff0c;但它們之間存在顯著的區別。以下是對兩者區別的詳細分析&#xff1a; 一、定義與核心功能 RPA&#xff08;機…

多模態大語言模型arxiv論文略讀(十五)

Jailbreaking GPT-4V via Self-Adversarial Attacks with System Prompts ?? 論文標題&#xff1a;Jailbreaking GPT-4V via Self-Adversarial Attacks with System Prompts ?? 論文作者&#xff1a;Yuanwei Wu, Xiang Li, Yixin Liu, Pan Zhou, Lichao Sun ?? 研究機構…

第1節:計算機視覺發展簡史

計算機視覺與圖像分類概述&#xff1a;計算機視覺發展簡史 計算機視覺&#xff08;Computer Vision&#xff09;作為人工智能領域的重要分支&#xff0c;是一門研究如何使機器"看"的科學&#xff0c;更具體地說&#xff0c;是指用攝影機和計算機代替人眼對目標進行識…

【工具】Fiddler抓包

本文主要講解如何使用Fiddler抓HTTP包&#xff0c;可通過所抓包內容分析HTTP請求/響應的細節 安裝與配置 1.下載與安裝 下載地址: https://www.telerik.com/fiddler/ 點擊了鏈接后&#xff0c;跳轉到以下頁面&#xff1a; 點擊Fiddler Classic(免費版)后&#xff0c;跳轉到以…

STM32F103復用JTAG/SWD引腳為GPIO

普中-精靈1開發板&#xff0c;主芯片為STM32F103C8T6&#xff0c;4個獨立按鍵K1~K4依次接PA15~PA12&#xff0c;按下為低電平&#xff0c;8個LED燈D1~D8&#xff0c;依次接PA0~PA7。查詢手冊得知&#xff1a;PA15主功能為JTDI&#xff0c;PA14為JTCK/SWCLK&#xff0c;PA13為JT…

難度偏低,25西電人工智能學院821、833、834考研錄取情況

1、人工智能學院各個方向 2、人工智能學院近三年復試分數線對比 學長、學姐分析 由表可看出&#xff1a; 1、智能院25年院線相對于24年院線 全部專業下降比較多&#xff0c;其中控制科學與工程下降20分&#xff0c;計算機科學與技術下降20分&#xff0c;計算機技術[專碩]下降…