【发布时间】:2019-05-01 07:35:45
【问题描述】:
我有以下功能,我需要清除数据库中的所有图片列并移动到文件系统。当我一口气完成所有这些时,内存太多,它会崩溃。我切换到递归函数并进行了 20 次的写入和批处理。
我需要为大约 6 张桌子执行此操作。我的 Realm DB 中有 2 个半演出数据。在我调用我的 6 个递归函数、取出图像并压缩 Realm 后,它会切换到 40mb。
我可以看到非常高的内存使用率,因为我的函数被调用并且内存较少的手机将无法处理它。
如何在每个函数之间释放内存和 CPU?
public static func clearEqCatPics(){
let docsDir = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first!
let eqcatPicDir = docsDir.appendingPathComponent(util_Constants.DIR_EQCAT_PICS)
do {
var realm : Realm? = try Realm()
let predicate = NSPredicate(format: "icon != %@", "")
let categories = realm!.objects(STD_EQ_category.self).filter(predicate).sorted( by: [SortDescriptor(keyPath: "displayorder", ascending: true), SortDescriptor(keyPath: "_id", ascending: true)] )
if (categories.count > 0)
{
realm?.beginWrite()
let upper = categories.count > 20 ? 20 : categories.count
var actualCounter = upper
for i in 0..<upper{
autoreleasepool{
if let proPicData = Data(base64Encoded: categories[actualCounter - 1].icon, options: .ignoreUnknownCharacters) {
let filename = eqcatPicDir.appendingPathComponent(categories[actualCounter - 1]._id.description+".jpg")
(proPicData as NSData).writeToURL2(named: filename, completion: { (result, url) -> Void in
})
categories[actualCounter - 1].icon = ""
}
else{
categories[actualCounter - 1].icon = ""
}
}
actualCounter = actualCounter - 1
}
try realm?.commitWrite()
let eqcatNew = realm!.objects(STD_EQ_category.self).filter(predicate)
print("$$$$$$$$$$$$$$$$$$$$ 2. eqcatNew COUNT : \(eqcatNew.count) $$$$$$$$$$$$$$$$$$$$")
realm = nil
if eqcatNew.count > 0 {
clearEqCatPics()
}
}
realm = nil
}
catch let error as NSError {
print("error realm \(error.localizedDescription)")
}
}
writeToURL2 在哪里:
我需要摆脱扩展程序中的弱自我,因为我正在通过多个项目的守卫让并且正在跳过负载
extension NSData {
func writeToURL2(named:URL, completion: @escaping (_ result: Bool, _ url:NSURL?) -> Void) {
let tmpURL = named as NSURL
//[weak self]
DispatchQueue.global(qos: .background).async { () -> Void in
//guard let strongSelf = self else { print("self was weak"); completion (false, tmpURL); return }
self.write(to: tmpURL as URL, atomically: true)
var error:NSError?
if tmpURL.checkResourceIsReachableAndReturnError(&error) {
print("We have it")
completion(true, tmpURL)
} else {
print("We Don't have it\(error?.localizedDescription)")
completion (false, tmpURL)
}
}
}
}
编辑:
我将 for 循环中的 writeToURL 更改为以下内容:
do {
try proPicData.write(to: filename, options: [.atomic])
}
catch let err as NSError{
print("err : \(err.localizedDescription)")
}
它有助于记忆,但有时我得到 Thread1: EXC_BAD_ACCESS 指向行 try proPicData.write...
仍然有很高的 CPU 使用率。是否有清除每个函数调用之间的 CPU 使用率?
【问题讨论】:
标签: swift recursion memory uiimage realm