C++中CopyFile和MoveFile函数使用区别的示例分析

 更新时间:2020年07月15日 11:55:13   作者:悦悦的小屋  
这篇文章主要介绍了C++中CopyFile和MoveFile函数使用区别的示例分析,CopyFile表示将文件A拷贝到B,如果B已经存在则覆盖,MoveFile表示将文件A移动到。对此感兴趣的可以来了解一下

1、函数定义

CopyFile(A, B, FALSE);表示将文件A拷贝到B,如果B已经存在则覆盖(第三参数为TRUE时表示不覆盖)

MoveFile(A, B);表示将文件A移动到B

2.函数原型

CopyFile:

MoveFile:

由函数原型可以看出,这两个函数的前两个输入参数都为LRCWSTR类型,如果我们定义的是char*,记得转换成LRCWSTR,否则会报错;

另外,这两个函数都返回一个bool型变量,表示执行成功与否,当目标位置路径不存在时,会return 0

3、Demo

示例一:

CopyFile:

#include <fstream>
#include <windows.h>
 
int main()
{
 char *fn = "test.txt";
 
 std::ofstream out(fn);
 if (!out.is_open())
  return 0;
 out.close();
 
 WCHAR buf[256];
 memset(buf, 0, sizeof(buf));
 MultiByteToWideChar(CP_ACP, 0, fn, strlen(fn) + 1, buf, sizeof(buf) / sizeof(buf[0]));
 CopyFile(buf, L"../file/output.txt", FALSE);//FALSE:如果目标位置已经存在同名文件,就覆盖,return 1
            //TRUE:如果目标位置已经存在同名文件,则补拷贝,return 0
            //后者路径若不错在,return 0
 system("pause");
 return 1;
}

CopyFile:

#include <fstream>
#include <windows.h>
 
int main()
{
 char *fn = "test.txt";
 
 std::ofstream out(fn);
 if (!out.is_open())
  return 0;
 out.close();
 
 WCHAR buf[256];
 memset(buf, 0, sizeof(buf));
 MultiByteToWideChar(CP_ACP, 0, fn, strlen(fn) + 1, buf, sizeof(buf) / sizeof(buf[0]));
 MoveFile(buf, L"../file/output.txt");//FALSE:将前者移动到后者中(后者路径若不错在,return 0)
 
 system("pause");
 return 1;
}

示例二:

#include <WINDOWS.H>
 
int main()
{
 char *sourcefile = "d://source//p.png";//源文件
 char *targetfile = "d://target//q.png";//目标文件
 CopyFile(sourcefile , targetfile , FALSE);//false代表覆盖,true不覆盖
 return 0;
}

4、将图片批量复制到另一个文件夹

//MyCopyFile.cpp#include <iostream>
#include <stdio.h>
#include <opencv2/opencv.hpp>
#include "io.h"
#include <fstream>
#include <WINDOWS.H>

//define the buffer size. Do not change the size!
#define DETECT_BUFFER_SIZE 0x20000
using namespace std;

//getFiles_Name函数声明,作用:读取path路径下的.png格式文件,并将每个.png文件的路径和文件名分别存储到files和filesname
void getFiles_Name(string path, vector<string>& files, vector<string>& filesname);

int main(void)
{
 vector<string> classnames;
 classnames.push_back(string("disgust"));
 classnames.push_back(string("neutral"));
 classnames.push_back(string("scream"));
 classnames.push_back(string("smile"));
 classnames.push_back(string("squint"));
 classnames.push_back(string("surprise"));

 for (int iexpress = 0; iexpress < 7;iexpress++)
 {
  string inputStr = "C:\\SourceFile\\" + classnames[iexpress];
  string outputStr = "C:\\TargetFile\\" + classnames[iexpress] + "\\";

  vector<string> files;
  vector<string> filesname;
  ////获取该路径下的所有文件 
  getFiles_Name(inputStr, files, filesname);

  //循环复制文件
  for (int k = 0; k < files.size(); k++)
  {
   unsigned char *pBuffer = (unsigned char *)malloc(DETECT_BUFFER_SIZE);
   if (!pBuffer)
   {
    fprintf(stderr, "Can not alloc buffer.\n");
    return -1;
   }

   cout << files[k] << endl;
   CopyFile(files[k].c_str(), (outputStr + filesname[k]).c_str(), FALSE);//false代表覆盖,true不覆盖
      //若文件路径为string类型变量,例如为pathstr,则需使用pathstr.c_str()转换即可;
   free(pBuffer);
  }
 }
 return 0;
}

void getFiles_Name(string path, vector<string>& files, vector<string>& filesname)
{
 //文件句柄 
 intptr_t hFile;
 //文件信息,声明一个存储文件信息的结构体 
 struct _finddata_t fileinfo;
 string p;//字符串,存放路径
    //string name;
 if ((hFile = _findfirst(p.assign(path).append("\\*.png").c_str(), &fileinfo)) != -1)//若查找成功,则进入
 {
  do
  {
   files.push_back(path + "\\" + fileinfo.name);
   filesname.push_back(fileinfo.name);
  } while (_findnext(hFile, &fileinfo) == 0);
  //_findclose函数结束查找
  _findclose(hFile);
 }
}

如果出现以下错误:

不能从const char*转换为LPCWSTR的原因及解决方法:

解决方法:

项目-->2.MyCopyFile属性-->3.配置属性-->4.常规-->5.字符集:改成 未设置

错误原因:

因为我的程序在UNICODE(宽字节)字符集下运行, UNICODE与ANSI有什么区别呢?简单的说,UNICODE版的字符比ANSI 的内存占用大,比如:Win32程式中出现的标准定义 char 占一个字节,而 char 的UNICODE版被定义成这样: typedef unsigned short wchar_t ;占2个字节。 所以有字符做参数的函数相应也用两个版本了。

参考博客:

https://blog.csdn.net/u012043391/article/details/77663644

https://blog.csdn.net/callmeado/article/details/21826679

https://www.cnblogs.com/dongsheng/p/3586418.html

https://blog.csdn.net/linjingtu/article/details/53190491

到此这篇关于C++中CopyFile和MoveFile函数的区别的文章就介绍到这了,更多相关C++中CopyFile和MoveFile函数的区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈C++中对象的复制与对象之间的相互赋值

    浅谈C++中对象的复制与对象之间的相互赋值

    这篇文章主要介绍了浅谈C++中对象的复制与对象之间的相互赋值,是C语言入门学习中的基础知识,需要的朋友可以参考下
    2015-09-09
  • C语言数据结构进阶之栈和队列的实现

    C语言数据结构进阶之栈和队列的实现

    栈和队列,严格意义上来说,也属于线性表,因为它们也都用于存储逻辑关系为 "一对一" 的数据,但由于它们比较特殊,因此将其单独作为一章,做重点讲解
    2021-11-11
  • C语言实现opencv提取直线、轮廓及ROI实例详解

    C语言实现opencv提取直线、轮廓及ROI实例详解

    这篇文章主要介绍了C语言实现opencv提取直线、轮廓及ROI实例详解,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • c++实现版本层次遍历功能

    c++实现版本层次遍历功能

    这篇文章主要介绍了c++实现版本层次遍历功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • C++中的new/delete、构造/析构函数、dynamic_cast分析

    C++中的new/delete、构造/析构函数、dynamic_cast分析

    这篇文章主要介绍了C++中的new/delete、构造/析构函数、dynamic_cast分析 本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • C语言中getchar()的返回类型为什么是int详解

    C语言中getchar()的返回类型为什么是int详解

    这篇文章主要给大家介绍了关于C语言中getchar()的返回类型为什么是int的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • C++运算符重载与多继承及二义性详解

    C++运算符重载与多继承及二义性详解

    继友元知识过后,就到了今天的C++运算符重载的内容了,运算符重载是C++里比较重要的内容。这篇博文不会一下子讲完各种运算符重载,因为太多了了也不好吸收掌握,所以运算符重载我准备分多次记录和分享,那么接下来进入正文
    2022-11-11
  • C++使用tinyxml库处理XML文件

    C++使用tinyxml库处理XML文件

    TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译,这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树,本文为大家介绍的是使用tinyxml库处理XML文件,需要的可以参考一下
    2023-07-07
  • C语言实现校园导游系统

    C语言实现校园导游系统

    这篇文章主要为大家详细介绍了C语言实现校园导游系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • C语言实现英文文本词频统计

    C语言实现英文文本词频统计

    这篇文章主要为大家详细介绍了C语言实现英文文本词频统计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03

最新评论