美文网首页
NSFileManager

NSFileManager

作者: Bleiler | 来源:发表于2017-11-24 16:00 被阅读117次

    1. 创建目录实例方法

    - (BOOL)createDirectoryAtPath:(NSString *)path withIntermediateDirectories:(BOOL)createIntermediates attributes:(nullable NSDictionary<NSFileAttributeKey, id> *)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

          本文链接:https://www.haomeiwen.com/subject/pvlfbxtx.html