所以今天早上我遇到了一个非常奇怪的问题。我有一个NSMutableString
随着时间的推移不断增长的文件,它偶尔会将自己保存到磁盘上,基本上是创建一个不断增长的文本文件。它运行良好,直到几个小时前。顺便说一句,我也没有更改方法中的任何代码。这是我正在使用的代码,NSMutableString
称为 stringToSave:
- (void)saveToTextFile {
NSLog(@"SaveTextToFile called");
// Get Current date and time:
NSDateFormatter *dateFormat = [[NSDateFormatter alloc] init];
[dateFormat setDateFormat:@"yyyy-MM-dd"];
NSDateFormatter *timeFormat = [[NSDateFormatter alloc] init];
[timeFormat setDateFormat:@"hh:mm"];
NSDate *now = [[NSDate alloc] init];
NSString *theDate = [dateFormat stringFromDate:now];
NSString *theTime = [timeFormat stringFromDate:now];
NSString *dateToBeDisplayed = [NSString stringWithFormat:@"Date: %@, Time: %@.", theDate, theTime];
// Create text to save, and save it.
stringToSave = [NSString stringWithFormat:@"\n %@ ",dateToBeDisplayed];
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *filePath = [documentsDirectory stringByAppendingPathComponent:@"mynotes"];
NSFileHandle *fileHandle = [NSFileHandle fileHandleForWritingAtPath:filePath];
[fileHandle seekToEndOfFile];
[fileHandle writeData:[stringToSave dataUsingEncoding:NSUTF8StringEncoding]];
[fileHandle closeFile];
// Check what's saved there.
NSString *content = [NSString stringWithContentsOfFile:filePath encoding:NSStringEncodingConversionAllowLossy error:nil];
NSLog(@"File Content: %@", content);
NSLog(@"stringtosave: %@", stringToSave);
}
奇怪的是,stringToSave
在 NSLog 中总是有正确的数据,而content
仍然是空的。有人认为我在上面保存数据的方式有什么问题吗?