NSData的用法(实现文件的复制)

来源:互联网 发布:api接口源码 编辑:程序博客网 时间:2024/06/15 16:13

NSData的contentsAtPath:方法仅仅是接受一个路径名,并将指定文件的内容读入该方法创建的存储区;如果读取成功,这个方法将返回存储区对象作为结果,否则(例如该文件不存在或者不能读取),将返回nil

方法createFileAtPath:contents:attributes:创建了一个具有特定属性(或者如果attributes参数提供为nil,则采用默认的属性值)的文件。然后,将指定的NSData对象内容写入这个文件中。

例如下面的例子,数据区包含前面读取的文件内容,实现了文件的复制操作:

[cpp] view plaincopy
  1. #import <Foundation/Foundation.h>  
  2.   
  3. int main(int argc, const char * argv[])  
  4. {  
  5.   
  6.     @autoreleasepool {  
  7.           
  8.         NSFileManager * fm;  
  9.         NSData *fileData;  
  10.           
  11.         fm = [NSFileManager defaultManager];  
  12.           
  13.         //读取文件testfile.txt  
  14.         fileData = [fm contentsAtPath:@"testfile.txt"];  
  15.           
  16.         if(fileData == nil)  
  17.         {  
  18.             NSLog(@"File read failed!");  
  19.             return 1;  
  20.         }  
  21.           
  22.         //将数据写到 newfile.txt  (相当于拷贝文件)  
  23.         if ([fm createFileAtPath:@"newfile.txt" contents:fileData attributes:nil] == NO)  
  24.         {  
  25.             NSLog(@"Couldn't create the copy!");  
  26.             return 2;  
  27.         }  
  28.           
  29.         NSLog(@"File copy was successful!");  
  30.           
  31.         //读取拷贝后的文件 newfile.txt中的数据  
  32.         NSLog(@"%@",[NSString stringWithContentsOfFile:@"newfile.txt" encoding:NSUTF8StringEncoding error:nil]);  
  33.           
  34.          
  35.     
  36.     }  
  37.     return 0;  
  38. }  
0 0
原创粉丝点击