【sudamod源码】【数字图像源码】【红帽停止提供源码】crc32 源码

时间:2025-01-23 04:53:43 分类:易语言编写驱动源码 来源:q友互助源码

1.CRC原理简介
2.c#压缩解压 文件夹

crc32 源码

CRC原理简介

       æœ€è¿‘刚好有时间,整理了一下关于CRC的资料,详细对比了下程序的实现过程和原理,当然,高手都是不在意的。

        本文主要介绍CRC的一些基础知识,个人收获是后面关于网上标准Demo程序的一些详细解析。见下一篇/p/c0dc2ece

        声明:本文定义部分参考网上多处资料,只是为了方便做个笔记,引用网文做一些更改,如有雷同,请私信说明并修改。

        一、关于CRC的介绍

        CRC即循环冗余校验码(Cyclic Redundancy Check):数据通信领域中最常用的一种差错校验码,其信息字段和校验字段长度可以任意指定,但要求通信双方定义的CRC标准一致。

        二、工作原理

        对于工控领域,我们主要利用CRC校验来处理各种数据流的数据正确性校验。

        CRC原理 :在K位信息码(目标发送数据)后再拼接R位校验码,使整个编码长度为N位,因此这种编码也叫(N,K)码。通俗的说,就是在需要发送的信息后面附加一个数(即校验码),生成一个新的发送数据发送给接收端。这个数据要求能够使生成的新数据被一个特定的数整除。这里的整除需要引入模 2除法的概念,附上百度百科关于模2计算的链接:

       /item/模2运算/?fr=aladdin

        那么,CRC校验的具体做法就是

        (1)选定一个标准除数(K位二进制数据串)

        (2)在要发送的数据(m位)后面加上K-1位0,然后将这个新数(M+K-1位)以模2除法的方式除以上面这个标准除数,所得到的余数也就是该数据的CRC校验码(注:余数必须比除数少且只少一位,不够就补0)

        (3)将这个校验码附在原m位数据后面,构成新的M+K-1位数据,发送给接收端。

        (4)接收端将接收到的数据除以标准除数,如果余数为0则认为数据正确。

        注意: CRC校验中有两个关键点:一是要预先确定一个发送端和接收端都用来作为除数的二进制比特串(或多项式);二是把原始帧与上面选定的除进行二进制除法运算,计算出FCS。前者可以随机选择,也可按国际上通行的标准选择,但最高位和最低位必须均为“1”

        实例:对于数据(#B3),以指定除数求它的CRC校验码,其过程如下:

        关于校验码的计算(重点来了)

        单纯谈CRC的模2除法其实并不困难,但实际计算中经常会遇到计算出来的结果和实际不一致的情况,这也是这几天我在看的东西。

        这里需要知道几个组成部分或者说计算概念:多项式公式、多项式简记式、数据宽度、初始值、结果异或值、输入值反转、输出值反转、参数模型。

        1、多项式公式

        对于CRC标准除数,一般使用多项式(或二项式)公式表示,如上例中除数的二项式为G(X)=X4+X3+X+1,X的指数就代表了该bit位上的数据为1,(最低位为0)。这里特别注意一下位数问题,除数的位数为二项式最高次幂+1(4+1=5),这个很重要。

        2、多项式简记式

        通过对CRC的基本了解我们知道,多项式的首尾必定为1,而这个1的位置在下一步计算一定为0,所以就把前面这个1给省略掉了,出现了一个叫简记式的东西,如上例中除数的简记式为,很多看过CRC高级语言源码的人会知道,对于CRC_标准下G(X)=X+X+X2+1(#)的poly值实际上是,这里使用的就是简记式。后面会对这个用法做一个说明。

        3、数据宽度

        数据宽度指的就是CRC校验码的长度(二进制位数),知道了CRC的运算概念和多项式,就可以理解这个概念了,CRC长度始终要比除数位数少1,与简记式长度是一致的。

        以上三个数据就是我们经常能够用到的基本数据

        4、初始值与结果异或值

        在一些标准中,规定了初始值,则数据在进行上述二项式运算之前,需要先将要计算的数据与初始值的最低字节进行异或,然后再与多项式进行计算。

        而在结果异或值不为零的情况下,则需要将计算得到的CRC结果值再与结果异或值进行一次异或计算,得到的最终值才是我们需要的CRC校验码。

        这里可以看出,初始值与结果值的位数要求与数据宽度一致。

        5、输入值反转与输出值反转

        输入值反转的意思是在计算之前先将二项式反转,然后再用得到的新值和数据进行计算。如对于G(X)=X+X+X2+1(#),其正向值为1 ,反转值则为 1

        输出值反转则是将最终得到的CRC结果反转。

        通常,输入值反转后的结果值也会是反转的,所以这两个选项一般是同向的,我们只有在在线CRC计算器中会看到自由选择正反转的情况存在。

        那么,这里引用CSDN博主 bobde 的一段总结:

        CRC、CRC等多字节的校验值的计算有几点需要清楚(只针对一次一个字节的算法):

        1) 初始值不为0的情况下,该如何计算:

        输入数据需要反转:先将要计算的数据与初始值的最低字节进行异或,再与反转后的多项式进行计算。

        输入数据不需要反转:先将要计算的数据左移到与初始值对齐的位置(如CRC算法,则左移8位,低位填充0;如CRC算法,则左移位,低位填充0)与初始值进行异或,再与正常的多项式进行计算。

        2) 结果异或值不为0的情况:第一步算得到的CRC值再与结果异或值进行异或操作得到最终的校验值:

        输出数据反转:如果输入数据是反转的模式,则结果也是反转的

        输出数据不反转:如果输入数据是不反转的模式,则结果也是不反转的

        3)初始值的选择是可自己定义,很多不同的厂家使用的初始值是不一样,不一样的初始值得到的结果也是不一样的。

        ---------------------

        原文:pression

        foreach (string file in filenames)

        {

        //打开压缩文件

        FileStream fs = File.OpenRead(file);

        byte[] buffer = new byte[fs.Length];

        fs.Read(buffer, 0, buffer.Length);

        ZipEntry entry = new ZipEntry(file);

        entry.DateTime = DateTime.Now;

        // set Size and the crc, because the information

        // about the size and crc should be stored in the header

        // if it is not set it is automatically written in the footer.

        // (in this case size == crc == -1 in the header)

        // Some ZIP programs have problems with zip files that don't store

        // the size and crc in the header.

        entry.Size = fs.Length;

        fs.Close();

        crc.Reset();

        crc.Update(buffer);

        entry.Crc = crc.Value;

        s.PutNextEntry(entry);

        s.Write(buffer, 0, buffer.Length);

        }

        s.Finish();

        s.Close();

        }

        }

       }

       现在再来看看解压文件类的源码

        /// <summary>

        /// 解压文件

        /// </summary>

       using System;

       using System.Text;

       using System.Collections;

       using System.IO;

       using System.Diagnostics;

       using System.Runtime.Serialization.Formatters.Binary;

       using System.Data;

       using ICSharpCode.SharpZipLib.BZip2;

       using ICSharpCode.SharpZipLib.Zip;

       using ICSharpCode.SharpZipLib.Zip.Compression;

       using ICSharpCode.SharpZipLib.Zip.Compression.Streams;

       using ICSharpCode.SharpZipLib.GZip;

       namespace DeCompression

       {

        public class UnZipClass

        {

        public void UnZip(string[] args)

        {

        ZipInputStream s = new ZipInputStream(File.OpenRead(args[0]));

        ZipEntry theEntry;

        while ((theEntry = s.GetNextEntry()) != null)

        {

        string directoryName = Path.GetDirectoryName(args[1]);

        string fileName = Path.GetFileName(theEntry.Name);

        //生成解压目录

        Directory.CreateDirectory(directoryName);

        if (fileName != String.Empty)

        {

        //解压文件到指定的目录

        FileStream streamWriter = File.Create(args[1]+theEntry.Name);

        int size = ;

        byte[] data = new byte[];

        while (true)

        {

        size = s.Read(data, 0, data.Length);

        if (size > 0)

        {

        streamWriter.Write(data, 0, size);

        }

        else

        {

        break;

        }

        }

        streamWriter.Close();

        }

        }

        s.Close();

        }

        }

       }

        有了压缩和解压缩的类以后,就要在窗体里调用了。sudamod源码怎么?是数字图像源码新手,不会调用?Ok,红帽停止提供源码接着往下看如何在窗体里调用。

        首先在窗体里放置两个命令按钮(不要告诉我你不会放啊~),轻奢云源码然后编写以下源码

       /// <summary>

        /// 调用源码

        /// </summary>

        private void button2_Click_1(object sender,怎么搭建源码系统 System.EventArgs e)

        {

        string []FileProperties=new string[2];

        FileProperties[0]="C:\\unzipped\\";//待压缩文件目录

        FileProperties[1]="C:\\zip\\a.zip"; //压缩后的目标文件

        ZipClass Zc=new ZipClass();

        Zc.ZipFileMain(FileProperties);

        }

        private void button2_Click(object sender, System.EventArgs e)

        {

        string []FileProperties=new string[2];

        FileProperties[0]="C:\\zip\\test.zip";//待解压的文件

        FileProperties[1]="C:\\unzipped\\";//解压后放置的目标目录

        UnZipClass UnZc=new UnZipClass();

        UnZc.UnZip(FileProperties);

        }

        好了,到此为止,如何压缩和解压缩的类都已经完成了,需要的朋友直接拿走调吧。