189 8069 5689

c++实现合并文件以及拆分实例代码

本文主要研究的是c++实现合并文件以及拆分的相关内容,分享了实现代码,具体如下。

十载的托里网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都营销网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整托里建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“托里网站设计”,“托里网站推广”以来,每个客户项目都认真落实执行。

昨天看到一篇介绍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

总结

以上就是本文关于c++实现合并文件以及拆分实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!


网站名称:c++实现合并文件以及拆分实例代码
文章链接:http://gzruizhi.cn/article/iejcpe.html

其他资讯