Zlib文件压缩和解压

开源代码:http://www.zlib.net/

zlib使用手册:http://www.zlib.net/manual.html

zlib wince版:http://www.tenik.co.jp/~adachi/wince/

在这里,你可以查看基于各种操作系统平台的压缩与解缩代码实现。

<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

以下是经过测试的 WinCE 及 WinXP 下的代码

<<<<<<<<

第一步: 首先到http://www.zlib.net/下载个ZLIB,

             WinXP: 解压缩后打开zlib-1.2.3\projects\visualc6\zlib.dsw,选择Win32 LIB Release 按F7编绎生成zlib.lib, zlib.dll.

            WinCE: 下载一个for Windows CE 版的包,里面针对各种平台(ARM4, ARM4I, MIPS, X86)有对应的zlibce.dll zlibce.lib.

<<<<<<<<

第二步: 建立EVC 或者 VS2005 的对话框工程.

             在工程中添加以下文件:zlib.h, zconf.h, zlib.lib, zlib.dll (或者 zlibce.dll);

            这3个文件就在刚才从http://www.zlib.net/下载的软件包中.

<<<<<<<<

第三步: 包含头文件

#include "zlib.h"

主要使用fopen等C标准接口实现的,只用到zlib的Compress()和UnCompress()接口;里面的条件编译是针对PC和WCE的

封装的类:

class CZlib

{

public:

 CZlib();

 ~ CZlib();

 int Compress(char * DestName,const char *SrcName);

 int UnCompress(char * DestName,const char *SrcName);

};

接口实现:

压缩

int CZlib::Compress(char * DestName,const char *SrcName)

{

    ] = {};  //压缩文件时的源buffer



    FILE* fp;  //打开欲压缩文件时文件的指针

    FILE* fp1;  //创建压缩文件时的指针 



    errno_t err; //错误变量的定义

#ifdef WINDOWS_PLATFORM

    err = fopen_s(&fp,SrcName,"r+b");//打开欲压缩的文件

    if(err)

    {

        printf("文件打开失败! \n");

        ;

    }

#endif 

#ifdef    WINDOWS_CE_PLATFORM

    fp = fopen_s(SrcName,"r+b");//打开欲压缩的文件

if(fp)

    {

        printf("文件打开失败! \n");

        ;

    }



#endif 



    

    //获取文件长度

    long cur = ftell(fp);

    fseek(fp,0L,SEEK_END);

    long fileLength = ftell(fp);

    fseek(fp,cur,SEEK_SET);





    //读取文件到buffer

    fread(SourceBuffer,fileLength,,fp);

    fclose(fp);



    //压缩buffer中的数据

    uLongf SourceBufferLen=;

    );

    err=compress((Bytef*)DestBuffer,(uLongf*)&SourceBufferLen,(const Bytef*)SourceBuffer,(uLongf)fileLength);

    if(err!=Z_OK)

    {

        cout<<"压缩失败:"<<err<<endl;

        ;

    }

    

    //创建一个文件用来写入压缩后的数据

    err = fopen_s(&fp1, DestName,"w+b");

    if(!fp1)

    {

        printf("压缩文件创建失败! \n");

         ;

    }



    fwrite(DestBuffer,SourceBufferLen,,fp1);

    fclose(fp1);

    ;

}

解压

int CZlib::UnCompress(char * DestName,const char *SrcName)

{

    ] = {};  //解压缩文件时的源buffer

    FILE* fp3;  //打开欲解压文件的文件指针

    FILE* fp4;  //创建解压文件的文件指针

    errno_t err; //错误变量的定义

    //打开欲解压的文件

    err = fopen_s(&fp3,SrcName,"r+b");

    if(err)

    {

        printf("文件打开失败! \n");

        ;

    }



    //获取欲解压文件的大小

    long ucur = ftell(fp3);

    fseek(fp3,0L,SEEK_END);

    long ufileLength = ftell(fp3);

    fseek(fp3,ucur,SEEK_SET);





    //读取文件到buffer

    fread(uSorceBuffer,ufileLength,,fp3);

    fclose(fp3);



    uLongf uDestBufferLen=;//此处长度需要足够大以容纳解压缩后数据

    );

    //解压缩buffer中的数据

    err=uncompress((Bytef*)uDestBuffer,(uLongf*)&uDestBufferLen,(Bytef*)uSorceBuffer,(uLongf)ufileLength);



    if(err!=Z_OK)

    {

        cout<<"解压缩失败:"<<err<<endl;

        ;

    }



    //创建一个文件用来写入解压缩后的数据

    err = fopen_s(&fp4,DestName,"wb");

    if(err)

    {

        printf("解压缩文件创建失败! \n");

         ;

    }



    printf("写入数据... \n");

    fwrite(uDestBuffer,uDestBufferLen,,fp4);

    fclose(fp4);

    ;

}

测试代码:

test.Compress("1.zip","test.docx");

test.UnCompress("11.docx","1.zip");

上述代码对于大文件就不适合了,因为是一次读出,一次写入的,下面是针对大文件的改进,分批读,分批写,代码如下:

WF_Error CZlib::Compress(const char * DestName,const char *SrcName)

{

    FILE * fp_in = NULL;;];



    WF_Error re = WF_OK;

    

    if( NULL == (fp_in = fopen(SrcName,"rb")))

    {

        return WF_FAIL;

    }



    /////////////////////////////////////////////

    gzFile out = gzopen(DestName,"wb6f");

    

    if(out == NULL)

    {

        return WF_FAIL;

    }



    for(;;)

    {

        len = fread(buf,,sizeof(buf),fp_in);

        

        if(ferror(fp_in))

        {

            re = WF_FAIL;

            break;

        }

        

        ) break;



        if(gzwrite(out, buf, (unsigned)len) != len)

        {

            re = WF_FAIL;

        }

    }



    gzclose(out);



    fclose(fp_in);



    return re;

 }



 WF_Error CZlib::UnCompress(const char * DestName,const char *SrcName)

{

    FILE * fp_out = NULL;WF_Error re = WF_OK;

    

    gzFile ;];



    in = gzopen(SrcName,"rb");



    if(in == NULL)

    {

        return WF_FAIL;

    }



    if(NULL == (fp_out = fopen(DestName,"wb")))

    {

        gzclose(in);

        return WF_FAIL;

    }

    

    for (;;)

    {

        len = gzread(in,buf,sizeof(buf));



        )

        {

            re = WF_FAIL;

            break;

        }



        ) break;



        ,(unsigned)len,fp_out)!=len)

        {

            re = WF_FAIL;

            break;

        }

    }



    fclose(fp_out);

    gzclose(in);



    return re;

}

【神经网络与深度学习】【C/C++】ZLIB学习2的更多相关文章

  1. (转)神经网络和深度学习简史(第一部分):从感知机到BP算法

    深度|神经网络和深度学习简史(第一部分):从感知机到BP算法 2016-01-23 机器之心 来自Andrey Kurenkov 作者:Andrey Kurenkov 机器之心编译出品 参与:chen ...

  2. 【译】神经网络与深度学习 Ch1-Section0

    用神经网络识别手写数字 人类的视觉系统是是大自然的奇迹.考虑下面手写数字序列: 大多数人能够轻易地是识别出是504192.在我们大脑的每个半球都有一个基础的皮质,这就是我们熟知的V1区,它包含了14亿 ...

  3. Neural Networks and Deep Learning(神经网络与深度学习) - 学习笔记

    catalogue . 引言 . 感知器及激活函数 . 代价函数(loss function) . 用梯度下降法来学习-Learning with gradient descent . 用反向传播调整 ...

  4. [DeeplearningAI笔记]神经网络与深度学习人工智能行业大师访谈

    觉得有用的话,欢迎一起讨论相互学习~Follow Me 吴恩达采访Geoffrey Hinton NG:前几十年,你就已经发明了这么多神经网络和深度学习相关的概念,我其实很好奇,在这么多你发明的东西中 ...

  5. Deep Learning.ai学习笔记_第一门课_神经网络和深度学习

    目录 前言 第一周(深度学习引言) 第二周(神经网络的编程基础) 第三周(浅层神经网络) 第四周(深层神经网络) 前言 目标: 掌握神经网络的基本概念, 学习如何建立神经网络(包含一个深度神经网络), ...

  6. 【吴恩达课后测验】Course 1 - 神经网络和深度学习 - 第二周测验【中英】

    [中英][吴恩达课后测验]Course 1 - 神经网络和深度学习 - 第二周测验 第2周测验 - 神经网络基础 神经元节点计算什么? [ ]神经元节点先计算激活函数,再计算线性函数(z = Wx + ...

  7. 【吴恩达课后测验】Course 1 - 神经网络和深度学习 - 第一周测验【中英】

    [吴恩达课后测验]Course 1 - 神经网络和深度学习 - 第一周测验[中英] 第一周测验 - 深度学习简介 和“AI是新电力”相类似的说法是什么? [  ]AI为我们的家庭和办公室的个人设备供电 ...

  8. 对比《动手学深度学习》 PDF代码+《神经网络与深度学习 》PDF

    随着AlphaGo与李世石大战的落幕,人工智能成为话题焦点.AlphaGo背后的工作原理"深度学习"也跳入大众的视野.什么是深度学习,什么是神经网络,为何一段程序在精密的围棋大赛中 ...

  9. 如何理解归一化(Normalization)对于神经网络(深度学习)的帮助?

    如何理解归一化(Normalization)对于神经网络(深度学习)的帮助? 作者:知乎用户链接:https://www.zhihu.com/question/326034346/answer/730 ...

  10. 【神经网络与深度学习】卷积神经网络(CNN)

    [神经网络与深度学习]卷积神经网络(CNN) 标签:[神经网络与深度学习] 实际上前面已经发布过一次,但是这次重新复习了一下,决定再发博一次. 说明:以后的总结,还应该以我的认识进行总结,这样比较符合 ...

随机推荐

  1. 关于int指令

    1.关于int指令 格式:int n     n为中断类型码: 作用:     调用n号中断程序:   指令“int n”的执行过程:     1]获取中断类型码n     2]标志寄存器入栈,IF. ...

  2. BZOJ 3667: Rabin-Miller算法 (Pollard-Rho 模板)

    说实话,我知道每一步都干啥,但我完全不知道为啥这么做,也不知道为什么是正确的,反正会用就行了~ #include <cmath> #include <cstdio> #incl ...

  3. Centos 7自定义屏幕分辨率

    $ xrandrScreen 0: minimum 1 x 1, current 1680 x 900, maximum 8192 x 8192Virtual1 connected primary 1 ...

  4. Jmeter(十一)函数助手

    可以在JMeter的选项菜单中找到函数助手对话框 我们可以从下拉列表中选择一个函数,并为其参数设定值.如图,表格的左边一列是函数参数的简要描述,右边一列是供用户填充参数的值.不同函数要求的参数也不同. ...

  5. ARTS打卡计划第三周

    Algorithms: https://leetcode-cn.com/problems/4sum/ 算法是先排序,然后按照一次循环按照三个数和两边逼中,考虑去重. Review: https://w ...

  6. redis 持久化 RDB

    https://blog.csdn.net/u010028869/article/details/51792197

  7. mini dc(选做)

    一.任务详情 提交测试截图和码云练习项目链接,实现Linux下dc的功能,计算后缀表达式的值 二.源代码 1.MyDC类 import java.util.StringTokenizer; impor ...

  8. PHP 验证5-20位数字加字母的正则(数字和字母缺一不可)!!!

    $pattern = '/^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{5,20}$/'; if(!preg_match($pattern,$username)){ re ...

  9. hibernate ifnull

    mysql中sql语句的ifnull函数,在hibernate的hql中可用coalesce代替. 例: mysql的sql:select ifnull(max(sort),0) from table ...

  10. PHP JQurey

    JQuery是用JS编写的程序,使用起来比JS更为简单,使用前需引入一个JQurey文件,下面为JQurey语法 <script type="text/javascript" ...