NSFileManager - NSFileManager 클래스는 파일 생성, 이동, 읽기, 쓰기, 그리고 파일의 속성 읽고 설정하기와 같은 기본적인 파일과 디렉토리 작업을 할 때 사용된다. 게다가 이 클래스는 현재 작업 중인 디렉토리를 식별하는 것과 새로운 디렉토리로 변경하는 것, 그리고 디렉토리를 생성하고 디렉토리에 있는 항목들을 나열하는 작업을 위한 메서드들을 제공한다.
NSFileHandle - NSFileHandle 클래스는 파일 내에서의 특정 위치를 찾는 것과 일정 크기의 바이트 양의 파일 내용을 읽고 쓰는 것과 기존의 파일에 데이터를 추가하는 것과 같이 낮은 수준의 작업을 수행하기 위하여 제공된 클래스다.
NSData - NSData 클래스는 읽어 온 파일의 내용이나 파일에 쓸 데이터를 위하여 유용한 저장 버퍼를 제공한다.
NSFileManager *filemgr; NSString *currentpath; filemgr = [NSFileManager defaultManager]; currentpath = filemgr currentDirectoryPath]; // 현재 작업 중인 디렉토리 if([filemgr changeCurrentDirectoryPath: @"/temp/mydir"] == NO) //디렉토리 변경 실패했을 경우 NSLog(@"Cannot change directory"); currentpath = [filemgr currentDirectoryPaht]; [filemgr createDirectoryAtPath: @".tmp/mynewdir", attributes: nil]; // 새로운 디렉토리 생성 [filemgr removeItemAtPath: @"/tmp/mynewdir" error:nil ]; // 디렉토리 삭제 [filemgr movePath:@"/tmp/mynewdir" toPath: @"/tmp/mynewdir2" handle:nil]; // 디렉토리 이름 변경과 이동 NSArray *filelist; filelist = [filemgr directoryContentsAtPath: @"/tmp"]; // 디렉토리에 있는 파일 목록 얻기 if([filemgr fileExistsAtPath: @"/tmp/myfile.txt"] == YES) // 파일이 있을 경우 NSLog(@"File exists"); if([filemgr contentsEqualAtPath: @"/tmp/myfile.txt" andPath: @"/tmp/sales.txt"] == YES) // 두 개의 파일 내용 비교 |
접근 권한 - 파일 경로를 인자로 받는다
- isReadableFileAtPath:
- isWritableFileAtPath:
- isExecutableFileAtPath:
- isDeletableFileAtPath;
NSFileManager *filemgr; NSData *databuffer; filemgr = [NSFileManager defaultManager]; databuffer = [filemgr contentsAtPath: @"/tmp/myfile.txt"]; // 내용 담기 |
NSString *homedir; |
* NSCopying 프로토콜을 사용하여 객체를 복사하면 복사한 객체의 값이 변하더라도 원본 객체의 값에는 변화가 없다.