方法一:access函数判断文件夹或者文件是否存在
函数原型: int _access(const char *filename, int mode);
所属头文件:io.h
filename:可以填写文件夹路径或者文件路径
mode:0 (F_OK) 只判断是否存在
2 (R_OK) 判断写入权限
4 (W_OK) 判断读取权限
6 (X_OK) 判断执行权限
头文件:<io.h>
函数原型:int _access(const char *pathname, int mode);
参数:pathname 为文件路径或目录路径 mode 为访问权限(在不同系统中可能用不能的宏定义重新定义)
返回值:如果文件具有指定的访问权限,则函数返回0;如果文件不存在或者不能访问指定的权限,则返回-1.
备注:当pathname为文件时,_access函数判断文件是否存在,并判断文件是否可以用mode值指定的模式进行访问。当pathname为目录时,_access只判断指定目录是否存在,在Windows NT和Windows 2000中,所有的目录都只有读写权限。
mode的值和含义如下所示:
00——只检查文件是否存在
02——写权限
04——读权限
06——读写权限
对应的还有_access的宽字符版本,用法相同
错误代码
EACCESS 参数pathname 所指定的文件不符合所要求测试的权限。
EROFS 欲测试写入权限的文件存在于只读文件系统内。
EFAULT 参数pathname指针超出可存取内存空间。
EINVAL 参数mode 不正确。
ENAMETOOLONG 参数pathname太长。
ENOTDIR 参数pathname为一目录。
ENOMEM 核心内存不足
ELOOP 参数pathname有过多符号连接问题。
EIO I/O 存取错误。
特别提醒:使用access()做用户认证方面的判断要特别小心,例如在access()后再做open()的空文件可能会造成系统安全上的问题。
#include <stdio.h>
#include <io.h>
int main(void)
{
if ((_access("lll.bin", 0)) != -1)
{
cout << _access("lll.bin", 0) << endl;
printf("File IsExist.txt exists.n");
if ((_access("IsExist.txt", 2)) != -1)
printf("File IsExist.txt does not have write permission.\n");
}
else
{
cout << "*****" << endl;
cout << _access("lll.bin", 0) << endl;
}
return 0;
}
fopen函数判断文件是否存在
函数原型:FILE *fopen (char *filename, char *type);
filename:文件路径
type:打开文件的方式(有r、w、r+、w+、a、rb、wb等等)
用于判断文件是否存在可以使用 r 或者 rb ,因为使用 其它方式的话,可能会自动建立文件。 返回值为NULL(打不开)和正数(能打开)。
特别提醒:用这种方法做出的判断是不完全正确的,因为有的文件存在,但是可能不可读。
// Test_VS2013.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include<iostream>
#include <fstream>
#include <string>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
fstream _file;
string path = "D:\\Test\\2.jpg";
_file.open(path, ios::in);
if (!_file)
{
cout << path << " 没有被创建" << endl;
}
else
{
cout << path << " 已经存在" << endl;
}
system("pause");
return 0;
}