时间:2021-05-20
本文主要研究的是c++实现合并文件以及拆分的相关内容,分享了实现代码,具体如下。
昨天看到一篇介绍TFS的文章,大意是为了处理海量图片,采用分布式架构,将小图片合并为大的文件
兴趣驱使下,写了一个简单的文件合并拆分程序
合并的方法很简单,将小文件写入到大文件中,使用二进制的方式。在大文件头,用一个int记录合并进来的小文件的数量,接下来,一块一块的写入小文件。
每一块都分为三个部分,第一部分是文件的名称,用20个char 来记录;第二部分用一个int来记录小文件的长度;第三部分则是小文件的实际内容
这样,在拆分时,通过文件头部获得小文件的数量,然后逐个获取名称,文件长度以及内容
附上源代码
合并:
void Merge() { char name[20]; string str1 = "F:/数据/1.jpg"; string str2 = "F:/数据/2.jpg"; string strBlock = "F:/数据/BLOCK.dat"; FILE* f1 = fopen(str1.c_str(),"rb+"); FILE* f2 = fopen(str2.c_str(),"rb+"); FILE* f3 = fopen(strBlock.c_str(),"rb+"); // 获取文件的长度 int iLen1 =filelength(fileno(f1)); int iLen2 = filelength(fileno(f2)); char *buf1 = new char[iLen1]; memset(buf1,0x0,iLen1); char *buf2 = new char[iLen2]; memset(buf2,0x0,iLen2); // 获取文件内容 fread(buf1,iLen1,1,f1); fread(buf2,iLen2,1,f2); fclose(f1); fclose(f2); // 在文件头记录合并文件的个数 int iCount = 2; fseek(f3,0,SEEK_SET); fwrite(&iCount,sizeof(int),1,f3); // 写入第一个文件 memset(name,0x0,20); strcpy(name,str1.c_str()); fwrite(name,20,1,f3); fwrite(&iLen1,sizeof(int),1,f3); fwrite(buf1,iLen1,1,f3); // 写入第二个文件 memset(name,0x0,20); strcpy(name,str2.c_str()); fwrite(name,20,1,f3); fwrite(&iLen2,sizeof(int),1,f3); fwrite(buf2,iLen2,1,f3); fclose(f3); //删除申请的内存 delete[] buf1; delete[] buf2; }拆分:
void Split() { char name[20]; string strBlock = "F:/数据/BLOCK.dat"; FILE* f3 = fopen(strBlock.c_str(),"rb+"); // 获取文件数量 int iCount = 0; fseek(f3,0,SEEK_SET); fread(&iCount,sizeof(int),1,f3); for(int i=0;i<iCount;i++) { memset(name,0x0,20); fread(&name,20,1,f3); // 输出名称 cout<<name<<endl; int iLen = 0; // 读取文件长度 fread(&iLen,sizeof(int),1,f3); char *buff = new char[iLen]; // 读取文件内容 fread(buff,iLen,1,f3); char fileLen[10]; sprintf(fileLen, "%d", iLen); // 以文件长度做名称 string s = fileLen; string strName = "F:/数据/"; strName += s; strName += string(".jpg") ; // 新建一个文件 FILE* file= fopen(strName.c_str(),"wb+"); fwrite(buff,iLen,1,file); fclose(file); } fclose(f3); }总结
以上就是本文关于c++实现合并文件以及拆分实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C++实现合并排序的方法。分享给大家供大家参考。具体如下://合并排序#include#includeusingnamespacestd;intn
本文实例讲述了C/C++函数调用栈的实现方法。可用于实现简单的脚本解释器。分享给大家供大家参考。具体实现方法如下:头文件声明部分:复制代码代码如下:#pragm
本文实例讲述了C++模板类的用法,分享给大家供大家参考。具体实现方法如下:main.h头文件如下:复制代码代码如下:templateclassactioncon
本文实例讲述了C++检查某个文件或目录是否存在的函数代码,分享给大家供大家参考。具体实现方法如下:#includeBOOLFileExists(LPCTSTRl
C++中实现矩阵的加法和乘法实例实现效果图:实例代码:#includeusingnamespacestd;classMatrix{introw;//矩阵的行in