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;
- }