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. Python 判断文件是否存在,不存在则将名称写入指定文件

    import os filename = '15464657761111111.pdf' pathDir = 'F:/tqcs/sr' # 判断文件是否存在 if os.path.exists(pat ...

  2. 51nod 1850 抽卡大赛 (十二省联考模测) DP

    O(n4)O(n^4)O(n4)的DP很好想,但是过不了.来看看O(n3)O(n^3)O(n3)的把. Freopen的博客 CODE #include <cstdio> #include ...

  3. Acwing-165-小猫爬山(搜索)

    链接: https://www.acwing.com/problem/content/167/ 题意: 翰翰和达达饲养了N只小猫,这天,小猫们要去爬山. 经历了千辛万苦,小猫们终于爬上了山顶,但是疲倦 ...

  4. 在Ubuntu 18.04系统中蓝牙鼠标连接失败问题的解决

    2018-08-22 16:00:35作者:谖瓞稿源:linux站 如果你在Ubuntu 18.04操作系统中有蓝牙鼠标连接失败问题,那就参考下面的解决方法处理. 解决方法 首先在系统终端下输入: b ...

  5. flask框架(十二):上下文管理***

    情况一:单进程单线程 基于全局变量实现. 情况二:单进程多线程 基于threading.local对象. threading.local对象,用于为每个线程开辟一块空间来保存它独有的值. # -*- ...

  6. vue中使用laydate.js插件

    1.到官网下载laydate.js https://www.layui.com/laydate/ 2.下载好后,将包解压好放在index.html同级的地方.我是在public中建立个statick文 ...

  7. UCenter网站部署

    搭建LAMP环境部署UCenter LAMP环境: Linux+Apache+mysql+php  用来搭建动态网站或者服务器的开源软件 一.需要安装的软件 [root@tiandong ~]# yu ...

  8. vue + ts Vuex篇

    Vuex对Typescript的支持,仍十分薄弱,官方库只是添加了一些.d.ts声明文件,并没有像vue 2.5这样内置支持. 第三方衍生库 vuex-typescript, vuex-ts-deco ...

  9. mini dc(选做)

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

  10. legend3---lavarel安装debugbar工具条

    legend3---lavarel安装debugbar工具条 一.总结 一句话总结: ` lavarel插件一般是composer官网下载,然后config/app.php中声明和加别名 ` 直接照官 ...