NSFileManager

1. 创建目录实例方法

- (BOOL)createDirectoryAtPath:(NSString *)path withIntermediateDirectories:(BOOL)createIntermediates attributes:(nullable NSDictionary *)attributes error:(NSError **)error API_AVAILABLE(macos(10.5), ios(2.0), watchos(2.0), tvos(9.0));

很多人使用这个接口时,往往将attributes参数设置为nil,这样虽然能够创建出目录,但是在一些特殊场景下(比如iPhone的apps)所创建的目录的属性往往不是我们期望的,因而导致目录的读写失败等问题。其实通过设置attributes参数,这个接口可以完成我们的期望。

根据苹果官方文档介绍,这个参数可以设置所创建目录所属的用户和用户组,目录的访问权限和修改时间等。如果设置为nil,那么所创建目录的属性则采用系统默认设置,一般会将目录的用户设置为root,访问权限设置为0755,这样就导致其他用户向这个目录写入时失败。

attributes参数是一个字典类型。查看苹果官方文档的介绍,可以看到在NSFileManager.h头文件定义了很多常量字符串,用于作为attributes字典的键,针对于这个接口的键主要包括下面几个:

NSFileAppendOnly: 这个键的值需要设置为一个表示布尔值的NSNumber对象,表示创建的目录是否是只读的。
NSFileCreationDate: 这个键的值需要设置为一个NSDate对象,表示目录的创建时间。
NSFileOwnerAccountName: 这个键的值需要设置为一个NSString对象,表示这个目录的所有者的名字。
NSFileGroupOwnerAccountName: 这个键的值需要设置为一个NSString对象,表示这个目录的用户组的名字。
NSFileGroupOwnerAccountID: 这个键的值需要设置为一个表示unsigned int的NSNumber对象,表示目录的组ID。
NSFileModificationDate: 这个键的值需要设置一个NSDate对象,表示目录的修改时间。
NSFileOwnerAccountID: 这个键的值需要设置为一个表示unsigned int的NSNumber对象,表示目录的所有者ID。
NSFilePosixPermissions: 这个键的值需要设置为一个表示short int的NSNumber对象,表示目录的访问权限。
NSFileReferenceCount: 这个键的值需要设置为一个表示unsigned long的NSNumber对象,表示目录的引用计数,即这个目录的硬链接数。

2. 判断指定路径文件或目录是否存在, 以及判断是文件还是目录

- (BOOL)fileExistsAtPath:(NSString *)path isDirectory:(nullable BOOL *)isDirectory;

其中实例方法返回一个bool值来表示指定路径文件或目录是否存在(YES存在、NO不存在)。
第二个参数需要传入一个BOOL变量的地址(用&)来表示指定路径是否是目录(YES是目录、NO不是目录)
第二个参数判断之前应当基于返回值为YES(表示存在文件或目录)时进行判断

你可能感兴趣的:(NSFileManager)