C++ 使用ZLIB库中的MiniZip实现目录压缩与解压

文章目录

  • 1、C++ 使用ZLIB库中的MiniZip实现递归目录压缩
  • 2、C++ 使用ZLIB库中的MiniZip实现递归目录解压缩
  • 3、使用过程遇到的问题

1、C++ 使用ZLIB库中的MiniZip实现递归目录压缩

Zlib是一个开源的数据压缩库,提供了一种通用的数据压缩和解压缩算法。它最初由Jean-Loup GaillyMark Adler开发,旨在成为一个高效、轻量级的压缩库,其被广泛应用于许多领域,包括网络通信、文件压缩、数据库系统等。其压缩算法是基于DEFLATE算法,这是一种无损数据压缩算法,通常能够提供相当高的压缩比。

Zlib项目中的contrib目录下有一个minizip子项目,minizip实际上不是zlib库的一部分,而是一个独立的开源库,用于处理ZIP压缩文件格式。它提供了对ZIP文件的创建和解压的简单接口。minizip在很多情况下与zlib一起使用,因为ZIP压缩通常使用了DEFLATE压缩算法。通过对minizip库的二次封装则可实现针对目录的压缩与解压功能。

在这里插入图片描述
如果你想使用minizip通常你需要下载并编译它,然后将其链接到你的项目中。

  • zlib源码:zlib源码下载。

编译Zlib库很简单,解压文件并进入到**\zlib-1.3\contrib\vstudio目录下,根据自己编译器版本选择不同的目录,这里我选择vc12**,进入后打开zlibvc.sln等待生成即可。
在这里插入图片描述

在这里插入图片描述
成功后可获得两个文件分别是zlibstat.libzlibwapi.lib如下图;
在这里插入图片描述
接着配置引用目录,这里需要多配置一个minizip头文件,该头文件是zlib里面的一个子项目。
在这里插入图片描述
lib库则需要包含zlibstat.libzlibwapi.lib这两个文件,此处可以自行放入到一个目录下;

在这里插入图片描述
在这里插入图片描述
ZIP 递归压缩目录:

  • 如下所示代码是一个使用zlib库实现的简单文件夹压缩工具的C++程序。该程序提供了压缩文件夹到 ZIP 文件的功能,支持递归地添加文件和子文件夹,利用了 Windows API 和 zlib 库的函数。
#define ZLIB_WINAPI
#include <string>
#include <iostream>
#include <vector>
#include <Shlwapi.h> 
#include <zip.h>
#include <unzip.h>
#include <zlib.h>using namespace std;#pragma comment(lib, "Shlwapi.lib")
#pragma comment(lib, "zlibstat.lib")bool AddfiletoZip(zipFile zfile, const std::string& fileNameinZip, const std::string& srcfile)
{// 目录如果为空则直接返回if (NULL == zfile || fileNameinZip.empty()){return 0;}int nErr = 0;zip_fileinfo zinfo = { 0 };tm_zip tmz = { 0 };zinfo.tmz_date = tmz;zinfo.dosDate = 0;zinfo.internal_fa = 0;zinfo.external_fa = 0;char sznewfileName[MAX_PATH] = { 0 };memset(sznewfileName, 0x00, sizeof(sznewfileName));strcat_s(sznewfileName, fileNameinZip.c_str());if (srcfile.empty()){strcat_s(sznewfileName, "\\");}nErr = zipOpenNewFileInZip(zfile, sznewfileName, &zinfo, NULL, 0, NULL, 0, NULL, Z_DEFLATED, Z_DEFAULT_COMPRESSION);if (nErr != ZIP_OK){return false;}if (!srcfile.empty()){// 打开源文件FILE* srcfp = _fsopen(srcfile.c_str(), "rb", _SH_DENYNO);if (NULL == srcfp){std::cout << "打开源文件失败" << std::endl;return false;}// 读入源文件写入zip文件int numBytes = 0;char* pBuf = new char[1024 * 100];if (NULL == pBuf){std::cout << "新建缓冲区失败" << std::endl;return 0;}while (!feof(srcfp)){memset(pBuf, 0x00, sizeof(pBuf));numBytes = fread(pBuf, 1, sizeof(pBuf), srcfp);nErr = zipWriteInFileInZip(zfile, pBuf, numBytes);if (ferror(srcfp)){break;}}delete[] pBuf;fclose(srcfp);}zipCloseFileInZip(zfile);return true;
}bool CollectfileInDirtoZip(zipFile zfile, const std::string& filepath, const std::string& parentdirName)
{if (NULL == zfile || filepath.empty()){return false;}bool bFile = false;std::string relativepath = "";WIN32_FIND_DATAA findFileData;char szpath[MAX_PATH] = { 0 };if (::PathIsDirectoryA(filepath.c_str())){strcpy_s(szpath, sizeof(szpath) / sizeof(szpath[0]), filepath.c_str());int len = strlen(szpath) + strlen("\\*.*") + 1;strcat_s(szpath, len, "\\*.*");}else{bFile = true;strcpy_s(szpath, sizeof(szpath) / sizeof(szpath[0]), filepath.c_str());}HANDLE hFile = ::FindFirstFileA(szpath, &findFileData);if (NULL == hFile){return false;}do{if (parentdirName.empty())relativepath = findFileData.cFileName;else// 生成zip文件中的相对路径relativepath = parentdirName + "\\" + findFileData.cFileName;// 如果是目录if (findFileData.dwFileAttributes == FILE_ATTRIBUTE_DIRECTORY){// 去掉目录中的.当前目录和..前一个目录if (strcmp(findFileData.cFileName, ".") != 0 && strcmp(findFileData.cFileName, "..") != 0){nyAddfiletoZip(zfile, relativepath, "");char szTemp[MAX_PATH] = { 0 };strcpy_s(szTemp, filepath.c_str());strcat_s(szTemp, "\\");strcat_s(szTemp, findFileData.cFileName);nyCollectfileInDirtoZip(zfile, szTemp, relativepath);}continue;}char szTemp[MAX_PATH] = { 0 };if (bFile){//注意:处理单独文件的压缩strcpy_s(szTemp, filepath.c_str());}else{//注意:处理目录文件的压缩strcpy_s(szTemp, filepath.c_str());strcat_s(szTemp, "\\");strcat_s(szTemp, findFileData.cFileName);}nyAddfiletoZip(zfile, relativepath, szTemp);} while (::FindNextFileA(hFile, &findFileData));FindClose(hFile);return true;
}/*
* 函数功能 : 压缩文件夹到目录
* 备    注 : dirpathName 源文件/文件夹
*      zipFileName 目的压缩包
*      parentdirName 压缩包内名字(文件夹名)
*/
bool CreateZipfromDir(const std::string& dirpathName, const std::string& zipfileName, const std::string& parentdirName)
{bool bRet = false;/*APPEND_STATUS_CREATE    创建追加APPEND_STATUS_CREATEAFTER 创建后追加(覆盖方式)APPEND_STATUS_ADDINZIP    直接追加*/zipFile zFile = NULL;if (!::PathFileExistsA(zipfileName.c_str())){zFile = zipOpen(zipfileName.c_str(), APPEND_STATUS_CREATE);}else{zFile = zipOpen(zipfileName.c_str(), APPEND_STATUS_ADDINZIP);}if (NULL == zFile){std::cout << "创建ZIP文件失败" << std::endl;return bRet;}if (nyCollectfileInDirtoZip(zFile, dirpathName, parentdirName)){bRet = true;}zipClose(zFile, NULL);return bRet;
}int main(int argc, char* argv[])
{std::string dirpath = "F:\\vs2013_code\\ConsoleApplication2\\Debug\\1.txt";                   // 源文件/文件夹std::string zipfileName = "F:\\vs2013_code\\ConsoleApplication2\\Debug\\test.zip";           // 目的压缩包//bool ref = nyCreateZipfromDir(dirpath, zipfileName, "lyshark");          // 包内文件名<如果为空则压缩时不指定目录>bool ref = nyCreateZipfromDir(dirpath, zipfileName, "a");          // 包内文件名<如果为空则压缩时不指定目录>std::cout << "[LyShark] 压缩状态 " << ref << std::endl;system("pause");return 0;
}
  • 主要功能

    • CreateZipfromDir函数:

      • bool CreateZipfromDir(const std::string& dirpathName, const std::string& zipfileName, const std::string& parentdirName);
      • 功能:压缩文件夹到指定的 ZIP 文件。
        • 参数:
          • dirpathName:源文件夹路径。
          • zipfileName:目标 ZIP 文件路径。
          • parentdirName:在 ZIP 文件内的文件夹名(如果为空则不指定目录)。
    • CollectfileInDirtoZip 函数:

      • bool CollectfileInDirtoZip(zipFile zfile, const std::string& filepath, const std::string& parentdirName);
        • 功能:递归地收集文件夹中的文件,并将它们添加到已打开的 ZIP 文件中。
          • 参数:
            • zfile:已打开的 ZIP 文件。
            • filepath:文件夹路径。
            • parentdirName:在 ZIP 文件内的相对文件夹名。
    • AddfiletoZip 函数:

      • bool AddfiletoZip(zipFile zfile, const std::string& fileNameinZip, const std::string& srcfile);
        • 功能:将指定文件添加到已打开的 ZIP 文件中。
          • 参数:
            • zfile:已打开的 ZIP 文件。
            • fileNameinZip:在 ZIP 文件内的相对文件路径。
            • srcfile:源文件路径。
  • 程序流程:

    • 文件夹压缩参数设置: 用户提供源文件夹路径、目标 ZIP 文件路径,以及在 ZIP 文件内的文件夹名。
    • ZIP 文件打开: 根据目标 ZIP 文件是否存在,使用 zipOpen 函数打开 ZIP 文件。
    • 文件夹递归添加: 使用 CollectfileInDirtoZip 函数递归地收集文件夹中的文件,并通过 AddfiletoZip 函数将它们添加到 ZIP 文件中。
    • ZIP 文件关闭: 使用 zipClose 函数关闭 ZIP 文件。
  • 示例用法

int main(int argc, char* argv[])
{std::string dirpath = "F:\\vs2013_code\\ConsoleApplication2\\Debug\\1.txt";                   // 源文件/文件夹std::string zipfileName = "F:\\vs2013_code\\ConsoleApplication2\\Debug\\test.zip";           // 目的压缩包//bool ref = nyCreateZipfromDir(dirpath, zipfileName, "lyshark");          // 包内文件名<如果为空则压缩时不指定目录>bool ref = nyCreateZipfromDir(dirpath, zipfileName, "a");          // 包内文件名<如果为空则压缩时不指定目录>std::cout << "[LyShark] 压缩状态 " << ref << std::endl;system("pause");return 0;
}
  • 上述调用代码,参数1指定为需要压缩的文件目录,参数2指定为需要压缩成目录名,参数3为压缩后该目录的名字。
    在这里插入图片描述

2、C++ 使用ZLIB库中的MiniZip实现递归目录解压缩

  • 在这个C++程序中,实现了递归解压缩ZIP文件的功能。程序提供了以下主要功能:
    • replace_all 函数: 用于替换字符串中的指定子串。
    • CreatedMultipleDirectory 函数: 用于创建多级目录,确保解压缩时的目录结构存在。
    • UnzipFile 函数: 用于递归解压缩 ZIP 文件。该函数打开 ZIP 文件,获取文件信息,然后逐个解析和处理 ZIP 文件中的文件或目录:
#define ZLIB_WINAPI
#include <string>
#include <iostream>
#include <vector>
#include <Shlwapi.h> 
#include <zip.h>
#include <unzip.h>
#include <zlib.h>using namespace std;#pragma comment(lib, "Shlwapi.lib")
#pragma comment(lib, "zlibstat.lib")// 将字符串内的old_value替换成new_value
std::string& replace_all(std::string& str, const std::string& old_value, const std::string& new_value)
{while (true){std::string::size_type pos(0);if ((pos = str.find(old_value)) != std::string::npos)str.replace(pos, old_value.length(), new_value);elsebreak;}return str;
}// 创建多级目录
BOOL CreatedMultipleDirectory(const std::string& direct)
{std::string Directoryname = direct;if (Directoryname[Directoryname.length() - 1] != '\\'){Directoryname.append(1, '\\');}std::vector< std::string> vpath;std::string strtemp;BOOL  bSuccess = FALSE;for (int i = 0; i < Directoryname.length(); i++){if (Directoryname[i] != '\\'){strtemp.append(1, Directoryname[i]);}else{vpath.push_back(strtemp);strtemp.append(1, '\\');}}std::vector< std::string>::iterator vIter = vpath.begin();for (; vIter != vpath.end(); vIter++){bSuccess = CreateDirectoryA(vIter->c_str(), NULL) ? TRUE : FALSE;}return bSuccess;
}/*
* 函数功能 : 递归解压文件目录
* 备    注 : strFilePath 压缩包路径
*      strTempPath 解压到
*/
void UnzipFile(const std::string& strFilePath, const std::string& strTempPath)
{int nReturnValue;string tempFilePath;string srcFilePath(strFilePath);string destFilePath;// 打开zip文件unzFile unzfile = unzOpen(srcFilePath.c_str());if (unzfile == NULL){return;}// 获取zip文件的信息unz_global_info* pGlobalInfo = new unz_global_info;nReturnValue = unzGetGlobalInfo(unzfile, pGlobalInfo);if (nReturnValue != UNZ_OK){std::cout << "数据包: " << pGlobalInfo->number_entry << endl;return;}// 解析zip文件unz_file_info* pFileInfo = new unz_file_info;char szZipFName[MAX_PATH] = { 0 };char szExtraName[MAX_PATH] = { 0 };char szCommName[MAX_PATH] = { 0 };// 存放从zip中解析出来的内部文件名for (int i = 0; i < pGlobalInfo->number_entry; i++){// 解析得到zip中的文件信息nReturnValue = unzGetCurrentFileInfo(unzfile, pFileInfo, szZipFName, MAX_PATH, szExtraName, MAX_PATH, szCommName, MAX_PATH);if (nReturnValue != UNZ_OK)return;std::cout << "解压文件名: " << szZipFName << endl;string strZipFName = szZipFName;// 如果是目录则执行创建递归目录名if (pFileInfo->external_fa == FILE_ATTRIBUTE_DIRECTORY || (strZipFName.rfind('/') == strZipFName.length() - 1)){destFilePath = strTempPath + "//" + szZipFName;CreateDirectoryA(destFilePath.c_str(), NULL);}// 如果是文件则解压缩并创建else{// 创建文件 保存完整路径string strFullFilePath;tempFilePath = strTempPath + "/" + szZipFName;strFullFilePath = tempFilePath;int nPos = tempFilePath.rfind("/");int nPosRev = tempFilePath.rfind("\\");if (nPosRev == string::npos && nPos == string::npos)continue;size_t nSplitPos = nPos > nPosRev ? nPos : nPosRev;destFilePath = tempFilePath.substr(0, nSplitPos + 1);if (!PathIsDirectoryA(destFilePath.c_str())){// 将路径格式统一destFilePath = replace_all(destFilePath, "/", "\\");// 创建多级目录int bRet = CreatedMultipleDirectory(destFilePath);}strFullFilePath = replace_all(strFullFilePath, "/", "\\");HANDLE hFile = CreateFileA(strFullFilePath.c_str(), GENERIC_WRITE, 0, NULL, OPEN_ALWAYS, FILE_FLAG_WRITE_THROUGH, NULL);if (hFile == INVALID_HANDLE_VALUE){return;}// 打开文件nReturnValue = unzOpenCurrentFile(unzfile);if (nReturnValue != UNZ_OK){CloseHandle(hFile);return;}// 读取文件uLong BUFFER_SIZE = pFileInfo->uncompressed_size;;void* szReadBuffer = NULL;szReadBuffer = (char*)malloc(BUFFER_SIZE);if (NULL == szReadBuffer){break;}while (TRUE){memset(szReadBuffer, 0, BUFFER_SIZE);int nReadFileSize = 0;nReadFileSize = unzReadCurrentFile(unzfile, szReadBuffer, BUFFER_SIZE);// 读取文件失败if (nReadFileSize < 0){unzCloseCurrentFile(unzfile);CloseHandle(hFile);return;}// 读取文件完毕else if (nReadFileSize == 0){unzCloseCurrentFile(unzfile);CloseHandle(hFile);break;}// 写入读取的内容else{DWORD dWrite = 0;BOOL bWriteSuccessed = WriteFile(hFile, szReadBuffer, BUFFER_SIZE, &dWrite, NULL);if (!bWriteSuccessed){unzCloseCurrentFile(unzfile);CloseHandle(hFile);return;}}}free(szReadBuffer);}unzGoToNextFile(unzfile);}delete pFileInfo;delete pGlobalInfo;// 关闭if (unzfile){unzClose(unzfile);}
}
  • 主要功能
    • replace_all 函数

      • std::string& replace_all(std::string& str, const std::string& old_value, const std::string& new_value)
      • 功能:在字符串 str 中替换所有的 old_value 为 new_value。
        • 参数:
          • str:待处理的字符串。
          • old_value:要被替换的子串。
          • new_value:替换后的新子串。
          • 返回值:替换后的字符串。
    • CreatedMultipleDirectory 函数

      • BOOL CreatedMultipleDirectory(const std::string& direct)
      • 功能:创建多级目录,确保路径存在。
        • 参数:
          • direct:目录路径。
          • 返回值:如果成功创建目录返回 TRUE,否则返回 FALSE。
    • UnzipFile 函数

      • void UnzipFile(const std::string& strFilePath, const std::string& strTempPath)
      • 功能:递归解压缩 ZIP 文件。
        • 参数:
          • strFilePath:ZIP 文件路径。
          • strTempPath:解压到的目标路径。
          • 该函数打开 ZIP 文件,获取文件信息,然后逐个解析和处理 ZIP 文件中的文件或目录。在解析过程中,根据文件或目录的属性,创建相应的目录结构,然后将文件写入目标路径。

示例用法:

int main(int argc, char* argv[])
{std::string srcFilePath = "D:\\lyshark\\test.zip";std::string tempdir = "D:\\lyshark\\test";// 如果传入目录不存在则创建if (!::PathFileExistsA(tempdir.c_str())){CreatedMultipleDirectory(tempdir);}// 调用解压函数UnzipFile(srcFilePath, tempdir);system("pause");return 0;
}

案例中,首先在解压缩之前判断传入目录是否存在,如果不存在则需要调用API创建目录,如果存在则直接调用UnzipFIle解压缩函数,实现解包,输出效果图如下;
在这里插入图片描述

3、使用过程遇到的问题

MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _rand 已经在 LIBCMT.lib(rand.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _srand 已经在 LIBCMT.lib(rand.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _free 已经在 LIBCMT.lib(free.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _malloc 已经在 LIBCMT.lib(malloc.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: __time64 已经在 LIBCMT.lib(time64.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _fclose 已经在 LIBCMT.lib(fclose.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _ferror 已经在 LIBCMT.lib(feoferr.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _fopen 已经在 LIBCMT.lib(fopen.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _fread 已经在 LIBCMT.lib(fread.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _fseek 已经在 LIBCMT.lib(fseek.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _ftell 已经在 LIBCMT.lib(ftell.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: __fseeki64 已经在 LIBCMT.lib(fseeki64.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: __ftelli64 已经在 LIBCMT.lib(ftelli64.obj) 中定义
1>MSVCRTD.lib(MSVCR90D.dll) : error LNK2005: _fwrite 已经在 LIBCMT.lib(fwrite.obj) 中定义
1>MSVCRTD.lib(ti_inst.obj) : error LNK2005: "private: __thiscall type_info::type_info(class type_info const &)" (??0type_info@@AAE@ABV0@@Z) 已经在 LIBCMT.lib(typinfo.obj) 中定义
1>MSVCRTD.lib(ti_inst.obj) : error LNK2005: "private: class type_info & __thiscall type_info::operator=(class type_info const &)" (??4type_info@@AAEAAV0@ABV0@@Z) 已经在 LIBCMT.lib(typinfo.obj) 中定义
1>   正在创建库 Release\sdologin.lib 和对象 Release\sdologin.exp
1>LINK : warning LNK4098: 默认库“MSVCRTD”与其他库的使用冲突;请使用 /NODEFAULTLIB:library
  • 遇到的错误是因为项目同时引用了两种不同的C运行时库(CRT):动态链接的调试库 MSVCRTD.lib 和静态链接的多线程库 LIBCMT.lib。这种冲突通常会在链接时导致 LNK2005 错误,因为同一个符号在两个库中都被定义了。

  • 要解决这个问题,你需要确保项目整体上只使用一种类型的CRT库。通常,解决方案涉及以下步骤:

    • 步骤 1: 确认项目的CRT设置:
      • 打开项目属性(右键项目 -> 属性)。
      • 导航到 配置属性 -> C/C++ -> 代码生成 -> 运行库。
      • 选择适当的运行库选项:
      • 对于调试版本,通常选择 多线程调试DLL (/MDd)。
      • 对于发布版本,选择 多线程DLL (/MD)。
      • 确保所有项目配置(Debug、Release等)都正确设置。

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/264704.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Ubuntu系统下搭建TDengine集群

目录 一、Ubuntu虚拟机创建 二、系统相关配置 1、设置系统hostname 2、网络配置及IP规划 3、配置FQDN&#xff08;etc/hosts&#xff09; 4、服务端口设置 三、TDengine server安装 1、服务安装 2、修改配置 3、启动taosd 4、服务卸载 四、客户端安装 1、client安…

Jmeter系列(2)目录介绍

目录 Jmeter目录介绍bin目录docsextrasliblicensesprintable_docs Jmeter目录介绍 在学习Jmeter之前&#xff0c;需要先对工具的目录有些了解&#xff0c;也会方便后续的学习 bin目录 examplesCSV目录中有CSV样例jmeter.batwindow 启动文件jmeter.shMac/linux的启动文件jmete…

大语言模型推理加速技术:计算加速篇

原文&#xff1a;大语言模型推理加速技术&#xff1a;计算加速篇 - 知乎 目录 简介 Transformer和Attention 瓶颈 优化目标 计算加速 计算侧优化 KVCache Kernel优化和算子融合 分布式推理 内存IO优化 Flash Attention Flash Decoding Continuous Batching Page…

车载测试面试:题库+项目

车载测试如何面试&#xff08;面试技巧&#xff09;https://blog.csdn.net/2301_79031315/article/details/136229809 入职车载测试常见面试题(附答案&#xff09;https://blog.csdn.net/2301_79031315/article/details/136229946 各大车企面试题汇总&#xff08;含答案&…

深搜+素数筛,LeetCode 2867. 统计树中的合法路径数目

一、题目 1、题目描述 给你一棵 n 个节点的无向树&#xff0c;节点编号为 1 到 n 。给你一个整数 n 和一个长度为 n - 1 的二维整数数组 edges &#xff0c;其中 edges[i] [ui, vi] 表示节点 ui 和 vi 在树中有一条边。 请你返回树中的 合法路径数目 。 如果在节点 a 到节点 …

请求包的大小会影响Redis每秒处理请求数量

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容压测规划客户端长连接数量对性能的影响请求包大小的影响Pipleline模式对Redis的影响 &#x1f4e2;文章总结&#x1f4e5;博主目标 &#x1f50a;博主介绍 &#x1f31f;我是廖志伟&#xff0c;一名Java开发工程师、Java领…

rtthread stm32h743的使用(二)DAPLINK下载程序不能启动

我们要在rtthread studio 开发环境中建立stm32h743xih6芯片的工程。我们使用一块stm32h743及fpga的核心板完成相关实验。 但是发现程序编译下载后不能启动&#xff0c;换为stlink后能够启动&#xff0c;反复试了好多次DAPLINK都不行&#xff0c;发送指令也没有反馈&#xff1a…

关于python的数据可视化与可视化:数据读取

带着问题寻找答案可以使自己不再迷茫或者不知所措&#xff01; 了解什么python的数据可视化&#xff1f; 数据的读取&#xff08;一般伴随着课程文件中会进行提供和利用&#xff09; 数据可视化是将Python应用于大气海洋科学中数据处理及分析过程的重要环节&#xff0c;它可以…

Python爬虫实战:从API获取数据

引言 在现代软件开发中&#xff0c;API已经成为获取数据的主要方式之一。API允许不同的软件应用程序相互通信&#xff0c;共享数据和功能。在本文中&#xff0c;我们将学习如何使用Python从API获取数据&#xff0c;并探讨其在实际应用中的价值。 目录 引言 二、API基础知识 …

tigramite教程(二)生物地球科学案例研究

文章目录 数据生成与绘图因果发现分析平稳性假设、确定性、潜在混杂因素结构假设参数假设使用PCMCIplus的滑动窗口分析聚合因果图非参数因果效应估计假设的图形和调整集干预的真实情况假设的参数模型和因果效应的估计使用关于图的不同假设进行估计非因果估计项目地址 这个文件…

目标检测-Transformer-ViT和DETR

文章目录 前言一、ViT应用和结论结构及创新点 二、DETR应用和结论结构及创新点 总结 前言 随着Transformer爆火以来&#xff0c;NLP领域迎来了大模型时代&#xff0c;成为AI目前最先进和火爆的领域&#xff0c;介于Transformer的先进性&#xff0c;基于Transformer架构的CV模型…

FL Studio20.8.3.2304 中文破解版功能更新(附2024最新图文激活教程)

FL Studio20.8中文开心版下载 (有能力的话还是建议支持正版) 绝对能用&#xff0c;我现在就在用着 版本是FL Studio 20.8.3.230420.8.3.2304 Image-Line公司成立20周年而发布的一个版本&#xff0c;FL Studio中文开心版是目前互联网上最优秀的完整的软件音乐制作环境或数字…

SpringBoot使用classfinal-maven-plugin插件加密Jar包

jar包加密 1、在启动类的pom.xml中加入classfinal-maven-plugin插件 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><plugin><…

from tensorflow.keras.layers import Dense,Flatten,Input报错无法引用

from tensorflow.keras.layers import Dense,Flatten,Input 打印一下路径&#xff1a; import tensorflow as tf import keras print(tf.__path__) print(keras.__path__) [E:\\开发工具\\pythonProject\\studyLL\\venv\\lib\\site-packages\\keras\\api\\_v2, E:\\开发工具\\…

小程序应用、页面、组件生命周期

引言 微信小程序生命周期是指在小程序运行过程中&#xff0c;不同阶段触发的一系列事件和函数。这一概念对于理解小程序的整体架构和开发流程非常重要。本文将介绍小程序生命周期的概念以及在不同阶段触发的关键事件&#xff0c;帮助开发者更好地理解和利用小程序的生命周期。 …

Docker基础(一)

文章目录 1. 基础概念2. 安装docker3. docker常用命令3.1 帮助命令3.2 镜像命令3.3 容器命令3.4 其他命令 4. 使用案例 1. 基础概念 镜像&#xff08;Image&#xff09;&#xff1a;Docker 镜像&#xff08;Image&#xff09;&#xff0c;就相当于是一个 root 文件系统。比如官…

ShardingSphere 5.x 系列【15】分布式主键生成器

有道无术,术尚可求,有术无道,止于术。 本系列Spring Boot 版本 3.1.0 本系列ShardingSphere 版本 5.4.0 源码地址:https://gitee.com/pearl-organization/study-sharding-sphere-demo 文章目录 1. 概述2. 配置3. 内置算法3.1 UUID3.2 Snowflake3.3 NanoId3.4 CosId3.5 Co…

深度学习目标检测】二十、基于深度学习的雾天行人车辆检测系统-含数据集、GUI和源码(python,yolov8)

雾天车辆行人检测在多种场景中扮演着至关重要的角色。以下是其作用的几个主要方面&#xff1a; 安全性提升&#xff1a;雾天能见度低&#xff0c;视线受阻&#xff0c;这使得驾驶者和行人在道路上的感知能力大大降低。通过车辆行人检测技术&#xff0c;可以在雾天条件下及时发现…

等保测评与商用密码共铸工控安全“双评合规”新篇章

最近听说了一个段子&#xff1a;“网络安全就像美女的内衣&#xff0c;等保和密评就是最贴身的内衣两件套&#xff0c;上下身一件都不能少。否则你的魔鬼身材&#xff08;核心数据&#xff09;就有可能被色狼&#xff08;黑客&#xff09;一览无余&#xff08;数据泄漏&#xf…

什么是nginx 、安装nginx、nginx调优

一、 什么是nginx 1.1 nginx的概念 一款高新能、轻量级Web服务软件系统资源消耗低对HTTP并发连接的处理能力高单台物理服务器可支持30 000&#xff5e;50 000个并发请求。 1.2 nginx模块与作用 核心模块&#xff1a;是 Nginx 服务器正常运行必不可少的模块&#xff0c;提供错…