场景说明

        协助同事解决fopen打开文件永远返回-1的异常情况。在解决问题的时候,先入为主的认为是:文件路径出现了字符转义的问题,根本没有想到要打印出当前无法获取到文件句柄的错误,是否是文件路径不存在。所以一开始就是将\替换为/,然后替换为\\,还是不行。

        单独写最简单的测试程序,没有问题。怀疑是Unicode编码的问题,也排除了。这时候就开始百度fopen失败的原因获取。刚开始的时候准备使用GetLastError函数,但是不能够确定是否是专属用于windows API,所以继续百度下面的结果:

fprintf(stderr, "%s \n",strerror(errno));结果没有任何的效果

如下是一段有用的信息:

        fopen内部用了CreateFile函数,所以fopen调用失败的情况下,也可以使用GetLastError查看错误代码。


解决方案:

    打开文件失败,调用GetLastError()函数,获取到DWORD的值是32,然后打开工具,选择查看错误码:进程无法访问文件,因为另一个程序正在访问该文件。通过查看所有的关于该文件的引用,果然发现确实已经有地方打开编辑该文件。


反思:如果是字符转义,肯定就是无法打开一个不存在的文件,只要通过获取错误码就可以解决这个问题。