我必须在 swift 中逐字符读取文件。我这样做的方式是从 FileHandler 读取一个块并返回字符串的第一个字符。
到目前为止,这是我的代码:
/// Return next character, or nil on EOF.
func nextChar() -> Character? {
precondition(fileHandle != nil, "Attempt to read from closed file")
if atEof {
return nil
}
if self.stored.characters.count > 0 {
let c: Character = self.stored.characters.first!
stored.remove(at: self.stored.startIndex)
return c
}
let tmpData = fileHandle.readData(ofLength: (4096))
print("\n---- file read ---\n" , terminator: "")
if tmpData.count == 0 {
return nil
}
self.stored = NSString(data: tmpData, encoding: encoding.rawValue) as String!
let c: Character = self.stored.characters.first!
self.stored.remove(at: stored.startIndex)
return c
}
我的问题是角色的返回非常慢。这是我的测试实现:
if let aStreamReader = StreamReader(path: file) {
defer {
aStreamReader.close()
}
while let char = aStreamReader.nextChar() {
print("\(char)", terminator: "")
continue
}
}
即使没有打印,也需要很长时间才能将文件读完。
对于 1.4mb 的示例文件,完成任务需要 6 多分钟。
time ./.build/debug/read a.txt
real 6m22.218s
user 6m13.181s
sys 0m2.998s
您对如何加快这部分的速度有意见吗?
let c: Character = self.stored.characters.first!
stored.remove(at: self.stored.startIndex)
return c
非常感谢。ps
++++ 更新功能 ++++
func nextChar() -> Character? {
//precondition(fileHandle != nil, "Attempt to read from closed file")
if atEof {
return nil
}
if stored_cnt > (stored_idx + 1) {
stored_idx += 1
return stored[stored_idx]
}
let tmpData = fileHandle.readData(ofLength: (chunkSize))
if tmpData.count == 0 {
atEof = true
return nil
}
if let s = NSString(data: tmpData, encoding: encoding.rawValue) as String! {
stored = s.characters.map { $0 }
stored_idx = 0
stored_cnt = stored.count
}
return stored[0];
}