c++实现合并文件以及拆分实例代码
作者:kwsy2008
这篇文章主要介绍了c++实现合并文件以及拆分实例代码,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
本文主要研究的是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++实现合并文件以及拆分实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!