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
1
解码字符串。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;