当 path = "c:\" 时,以下代码不会写入文件 c:\err.txt,因为权限被拒绝。但它不会同时产生错误。相反,它输出“OK”。
如何检查权限是否允许写入?
#include <cstdlib>
#include <iostream>
#include <fstream>
using namespace std;
bool writeLineToErr(string path, string err_line){
std::ofstream outfile(path+"err.txt", std::ios_base::app);
if(!outfile){
cout<<"Error 1 "+path+"err.txt"+" can't open file!";
return false;
}
if(outfile.fail()){
cout<<"Error 2 "+path+"err.txt"+" can't open file!";
return false;
}
outfile << err_line << endl;
cout<<"OK";
outfile.close();
return true;
}
int main(int argc, char** argv) {
writeLineToErr("c:\\","Some Line");
return 0;
}
我想说你的代码可以工作并且写入操作实际上已经完成,但为了它,在写入后也添加一个检查:
outfile << err_line << endl;
if(outfile.fail()) cout << "Error3\n";
else cout<<"OK";
在我的系统上,我会得到你的Error 1 ... can't open file
如果文件未打开并成功写入。
Edit:或者您正在运行 WindowsCompatibility Files
虚拟化还活跃吗?如果是这样,该文件可能位于虚拟商店,不是真实的C:\err.txt
path.
例子:C:\Users\username\AppData\Local\VirtualStore
如果你在那里找到它,你可能还会在那里找到很多其他东西。至少几年前当我遇到类似问题时我是这样做的。我决定手动移动(使用管理员权限)我的一些旧程序放在那里的几个重要文件,然后关闭虚拟商店。我找不到一个好的、简单的 Microsoft 官方链接来了解如何关闭文件和注册表虚拟化现在也许这会做:
注册表编辑:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System\
创建一个DWORD
带有名字的钥匙EnableVirtualization
并赋予它值0
。如果密钥已经存在,但设置为非零的值,请更改它。
这里还有更多:UAC组策略设置和注册表项设置 https://learn.microsoft.com/en-us/previous-versions/windows/it-pro/windows-server-2008-R2-and-2008/dd835564(v=ws.10)#BKMK_Virtualize
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)