ios开发之NSData

Posted free-thinker

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ios开发之NSData相关的知识,希望对你有一定的参考价值。

NSData用于保存字节数组。

初始化

- (instancetype)initWithBytesNoCopy:(void *)bytes length:(NSUInteger)length freeWhenDone:(BOOL)b;

初始化对象。
不进行复制字节数组操作,直接设置字节指针为bytes,长度为length。

- (instancetype)initWithBytesNoCopy:(void *)bytes length:(NSUInteger)length;

初始化对象。
不进行复制字节数组操作,直接设置字节指针为bytes,长度为length。

- (instancetype)initWithBytes:(nullable const void *)bytes length:(NSUInteger)length;

初始化对象。
复制字节数组,设置字节指针指向复制的字节数组,长度为length。

- (nullable instancetype)initWithContentsOfFile:(NSString *)path;


读取文件内容初始化对象。
读取成功则返回对象,如果失败则返回nil。

- (nullable instancetype)initWithContentsOfFile:(NSString *)path options:(NSDataReadingOptions)readOptionsMask error:(NSError **)errorPtr;


读取文件内容初始化对象。
读取成功则返回对象。如果失败则返回nil,错误信息保存在errorPtr中。
参数readOptionsMask 指定文件读取选项。

typedef NS_OPTIONS(NSUInteger, NSDataReadingOptions) 
    NSDataReadingMappedIfSafe =   1UL << 0, 
    NSDataReadingUncached = 1UL << 1,   
    NSDataReadingMappedAlways  = 1UL << 3,

    NSDataReadingMapped = NSDataReadingMappedIfSafe,
    NSMappedRead = NSDataReadingMapped,
    NSUncachedRead = NSDataReadingUncached
;

- (nullable instancetype)initWithContentsOfURL:(NSURL *)url;

读取url内容初始化对象。
读取成功则返回对象,如果失败则返回nil。

- (nullable instancetype)initWithContentsOfURL:(NSURL *)url options:(NSDataReadingOptions)readOptionsMask error:(NSError **)errorPtr;

读取url内容初始化对象。
读取成功则返回对象。如果失败则返回nil,错误信息保存在errorPtr中。
参数readOptionsMask 指定文件读取选项。

- (instancetype)initWithData:(NSData *)data;


根据NSData对象初始化对象。

- (nullable id)initWithContentsOfMappedFile:(NSString *)path

根据文件内容初始化对象。读取文件内容的方式不是read系统调用,而是mmap系统调用。

构造

+ (instancetype)data;

构造空的NSData对象。

+ (instancetype)dataWithBytesNoCopy:(void *)bytes length:(NSUInteger)length freeWhenDone:(BOOL)b;


根据字节数组构造对象。不复制字节数组。

+ (instancetype)dataWithBytesNoCopy:(void *)bytes length:(NSUInteger)length;


根据字节数组构造对象。不复制字节数组。

+ (instancetype)dataWithBytes:(nullable const void *)bytes length:(NSUInteger)length;


根据字节数组构造对象。复制字节数组。

 + (nullable instancetype)dataWithContentsOfFile:(NSString *)path;


根据文件内容构造对象。

+ (nullable instancetype)dataWithContentsOfFile:(NSString *)path options:(NSDataReadingOptions)readOptionsMask error:(NSError **)errorPtr;


根据文件内容构造对象。

 + (nullable instancetype)dataWithContentsOfURL:(NSURL *)url;


根据url内容构造对象。

+ (nullable instancetype)dataWithContentsOfURL:(NSURL *)url options:(NSDataReadingOptions)readOptionsMask error:(NSError **)errorPtr;


根据url内容构造对象。

+ (instancetype)dataWithData:(NSData *)data;


根据NSData对象构造对象。

+ (nullable id)dataWithContentsOfMappedFile:(NSString *)path


根据文件内容构造对象。读取文件内容的方式不是read系统调用,而是mmap系统调用。

返回长度

@property (readonly) NSUInteger length;


返回数据

@property (readonly) const void *bytes


返回区间内的数据

- (void)getBytes:(void *)buffer range:(NSRange)range;


参数buffer保存获取的数据,参数range指定获取数据的区间。

- (void)getBytes:(void *)buffer length:(NSUInteger)length;


获取指定长度的数据。如果length大于数据长度,则使用数据长度作为指定长度。

- (void)getBytes:(void *)buffer


获取所有数据。

截取数据

- (NSData *)subdataWithRange:(NSRange)range;


参数range指定截取区间。

是否相等

- (BOOL)isEqualToData:(NSData *)other;


比较数据是否相等。

写入文件

- (BOOL)writeToFile:(NSString *)path options:(NSDataWritingOptions)writeOptionsMask error:(NSError **)errorPtr;


参数path指定文件路径。参数errorPtr在写入失败时保存出错信息。参数writeOptionsMask 表示写入文件时的可选项,可使用或运算符连接。其可能值为

typedef NS_OPTIONS(NSUInteger, NSDataWritingOptions) 
NSDataWritingAtomic = 1UL << 0, 
NSDataWritingWithoutOverwriting NS_ENUM_AVAILABLE(10_8, 6_0) = 1UL << 1, 

NSDataWritingFileProtectionNone NS_ENUM_AVAILABLE_ios(4_0)  = 0x10000000,
NSDataWritingFileProtectionComplete NS_ENUM_AVAILABLE_IOS(4_0)  = 0x20000000,
NSDataWritingFileProtectionCompleteUnlessOpen NS_ENUM_AVAILABLE_IOS(5_0)  = 0x30000000,
NSDataWritingFileProtectionCompleteUntilFirstUserAuthentication NS_ENUM_AVAILABLE_IOS(5_0)  = 0x40000000,
NSDataWritingFileProtectionMask NS_ENUM_AVAILABLE_IOS(4_0)  = 0xf0000000,
NSAtomicWrite = NSDataWritingAtomic     
;

NSDataWritingAtomic 表示使用辅助文件完成原子操作。
NSDataWritingWithoutOverwriting 表示防止覆盖现有文件,不能与NSDataWritingAtomic 结合使用。

- (BOOL)writeToFile:(NSString *)path atomically:(BOOL)useAuxiliaryFile;


写入文件。参数path指定文件路径,参数useAuxiliaryFile使用辅助文件完成原子操作。

写入url

- (BOOL)writeToURL:(NSURL *)url options:(NSDataWritingOptions)writeOptionsMask error:(NSError **)errorPtr;


参数path指定url路径。参数errorPtr在写入失败时保存出错信息。参数writeOptionsMask 表示写入时的可选项,可使用或运算符连接。

- (BOOL)writeToURL:(NSURL *)url atomically:(BOOL)atomically;


写入url。参数path指定文件路径,参数atomically完成原子操作。

搜索

- (NSRange)rangeOfData:(NSData *)dataToFind options:(NSDataSearchOptions)mask range:(NSRange)searchRange


搜索数据。参数dataToFind为搜索的数据。参数searchRange为搜索的区间。参数mask 为搜索的方式。搜索方式可使用或运算符连接。
搜索方式有:

typedef NS_OPTIONS(NSUInteger, NSDataSearchOptions) 
    NSDataSearchBackwards = 1UL << 0,
    NSDataSearchAnchored = 1UL << 1



NSDataSearchBackwards表示从后向前搜索。
NSDataSearchAnchored表示只是搜索头部或尾部(与NSDataSearchBackwards连用)。

与Base64编码相关

- (nullable instancetype)initWithBase64EncodedString:(NSString *)base64String options:(NSDataBase64DecodingOptions)options


解码字符串。options为解码方式。

typedef NS_OPTIONS(NSUInteger, NSDataBase64DecodingOptions) 
    NSDataBase64DecodingIgnoreUnknownCharacters = 1UL << 0
 NS_ENUM_AVAILABLE(10_9, 7_0);


NSDataBase64DecodingIgnoreUnknownCharacters 表示忽略不知道的字符。

- (NSString *)base64EncodedStringWithOptions:(NSDataBase64EncodingOptions)options


编码为字符串。参数options为编码方式。

typedef NS_OPTIONS(NSUInteger, NSDataBase64EncodingOptions) 
    NSDataBase64Encoding64CharacterLineLength = 1UL << 0,
    NSDataBase64Encoding76CharacterLineLength = 1UL << 1,
    NSDataBase64EncodingEndLineWithCarriageReturn = 1UL << 4,
    NSDataBase64EncodingEndLineWithLineFeed = 1UL << 5,

 NS_ENUM_AVAILABLE(10_9, 7_0);


- (nullable instancetype)initWithBase64EncodedData:(NSData *)base64Data options:(NSDataBase64DecodingOptions)options


解码数据。

- (NSData *)base64EncodedDataWithOptions:(NSDataBase64EncodingOptions)options


编码数据。

- (nullable id)initWithBase64Encoding:(NSString *)base64String


解码字符串。

- (NSString *)base64Encoding


编码为字符串。
NSMutableData用于保存可变字节数组。

返回数据

@property (readonly) void *mutableBytes


返回长度

@property NSUInteger length;

初始化

- (nullable instancetype)initWithCapacity:(NSUInteger)capacity;


根据容量大小初始化对象。

- (nullable instancetype)initWithLength:(NSUInteger)length;


根据长度初始化对象。数组全部清空为0。

构造

 + (nullable instancetype)dataWithCapacity:(NSUInteger)aNumItems;


根据容量大小构造对象。

 + (nullable instancetype)dataWithLength:(NSUInteger)length;


根据长度构造对象。

添加

- (void)appendBytes:(const void *)bytes length:(NSUInteger)length;


添加数组。

- (void)appendData:(NSData *)other;

添加数据。

替换

- (void)replaceBytesInRange:(NSRange)range withBytes:(const void *)bytes;


替换字节数组。

- (void)replaceBytesInRange:(NSRange)range withBytes:(nullable const void *)replacementBytes length:(NSUInteger)replacementLength;


替换字节数组。参数replacementLength指定替换数组的长度。

增加长度

- (void)increaseLengthBy:(NSUInteger)extraLength;


重置

- (void)resetBytesInRange:(NSRange)range;


重置区间内数据为0。

设置

- (void)setData:(NSData *)data;

 

以上是关于ios开发之NSData的主要内容,如果未能解决你的问题,请参考以下文章

iOS开发系列文章(持续转载中……) 感谢作者,直接连接到作者文章的

IOS开发之记录用户登陆状态,ios开发用户登陆

iOS开发之手势识别汇总

李洪强iOS开发之 - 项目架构

iOS开发之苹果开发者账号注册申请流程

iOS开发之语音录制