关键字:
MoveFile, MoveFileEx, CopyFile, 文件只读属性, 文件隐藏属性,
GetFileAttributes, SetFileAttributes, 文件属性的读取与设置
1. 文件的只读和隐藏属性对函数的影响
1.1 移动操作(MoveFile和MoveFileEx)
testcase 1: 设源文件为c:/file1, 目标文件file2, 且目标文件不存在。
测试结果: file1的只读和隐藏属性对上面两个函数没有影响,函数返回后file1被更名为file2。文件的属性不变
testcase 2: 目标文件file2存在,属性为只读
测试结果: MoveFile失败,且与file2的只读属性无关,因为它不支持覆盖现有文件。
MoveFileEx的调用标志设为MOVEFILE_REPLACE_EXISTING时,file2的只读属性决定调用的成功与否, 和隐藏属性无关
1.2 拷贝操作(CopyFile)
MSDN在两个函数的文档中均有如下声明:
This function fails with ERROR_ACCESS_DENIED if the destination file already exists and has the FILE_ATTRIBUTE_HIDDEN or FILE_ATTRIBUTE_READONLY attribute set.
只需注意即可.
2. 跨卷操作
1.1 移动操作
MoveFile支持跨卷操作,参见MSDN中的说明:
A new file may be on a different file system or drive. A new directory must be on the same drive
MoveFileEx也支持跨卷操作,不过要设置MOVEFILE_COPY_ALLOWED标志
1.2 拷贝操作
支持跨卷操作
3. 设置文件属性的方法,以只读属性为例
文件属性操作使用SetFileAttributes和GetFileAttributes函数
具体说明参见MSDN
操作实例
// 测试某个属性是否被设置,以只读属性为例,其它类同
// 获取现有的文件属性
CString strPathName = _T("path and name of some file");
TCHAR szErr[255];
DWORD dwAttrs = ::GetFileAttributes(strPathName);
if(dwAttrs != INVALID_FILE_ATTRIBUTES)
{
if(dwAttrs & FILE_ATTRIBUTE_READONLY)
{
// 有只读属性
// 取消只读属性
dwAttrs &= ~FILE_ATTRIBUTE_READONLY;
}
else
{
// 无只读属性
// 设置只读属性
dwAttrs |= FILE_ATTRIBUTE_READONLY;
// 将属性设置到文件
if(!::SetFileAttributes(strPathName, dwAttrs))
{
// 打印错误信息
::FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, NULL, ::GetLastError(), 0, szErr, 255, NULL);
}
}
}
else
{
::FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, NULL, ::GetLastError(), 0, szErr, 255, NULL);
}
操作结果:
如果文件有只读属性,该属性将被取消,否则,该属性被设置
备注:
设置文件属性前要先获取当前的文件属性,然后再当前属性的基础上进行设置某或取消某项属性的操作,以免使其它属性被无意取消.
4. 总结
使用MoveFileEx的时候,要考虑目标文件的只读属性,使用CopyFile的时候,要考虑目标文件的只读和隐藏属性.
MoveFile不支持覆盖目标文件的操作
MoveFile支持跨卷操作,可以把文件移动到另一个逻辑分区或物理介质上,MoveFileEx也支持同样的操作,但设置MOVEFILE_COPY_ALLOWED标志位
CopyFile支持跨卷操作
本文没有涉及CopyFileEx, 调用它的代码在我的环境里不能成功编译.
在文件操作中包含目标文件的时候,一定要考虑到文件的只读和隐藏属性.确定要执行拷贝和移动到目标文件的时候,可以先把它的只读和隐藏属性去除,操作完成后,根据需求决定是否再把属性恢复回去. 还要注意目标文件是否在另外的卷上.
MoveFileEx函数功能很强大,但它只支持WindowsXP及更高版本的操作系统.所以对MoveFileEx需要谨慎使用.
CopyFileEx, GetFileAttributesEx, SetFileAttributesEx支持Windows98及更高版本的操作系统.
文件操作十分常用,注意这些细节,否则程序可能因为一个移动文件操作失败而崩溃.或因使用了高级函数而根本不能在宿主系统上运行