NSData的contentsAtPath:方法仅仅是接受一个路径名,并将指定文件的内容读入该方法创建的存储区;如果读取成功,这个方法将返回存储区对象作为结果,否则(例如该文件不存在或者不能读取),将返回nil
方法createFileAtPath:contents:attributes:创建了一个具有特定属性(或者如果attributes参数提供为nil,则采用默认的属性值)的文件。然后,将指定的NSData对象内容写入这个文件中。
例如下面的例子,数据区包含前面读取的文件内容,实现了文件的复制操作:
#import <Foundation/Foundation.h>
int main(int argc, const char * argv[])
{
@autoreleasepool {
NSFileManager * fm;
NSData *fileData;
fm = [NSFileManager defaultManager];
//读取文件testfile.txt
fileData = [fm contentsAtPath:@"testfile.txt"];
if(fileData == nil)
{
NSLog(@"File read failed!");
return 1;
}
//将数据写到 newfile.txt (相当于拷贝文件)
if ([fm createFileAtPath:@"newfile.txt" contents:fileData attributes:nil] == NO)
{
NSLog(@"Couldn't create the copy!");
return 2;
}
NSLog(@"File copy was successful!");
//读取拷贝后的文件 newfile.txt中的数据
NSLog(@"%@",[NSString stringWithContentsOfFile:@"newfile.txt" encoding:NSUTF8StringEncoding error:nil]);
}
return 0;
}