- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个非常奇怪的情况。我的服务器当前已关闭并收到 503 http 状态代码。基于如下给定的代码,代码进入 if 条件,但是当我将调试点置于 let error = self?.decodeErrorMessage(data: data, statusCode: response.statusCode)
时。然后它从 if 条件跳转并执行 else if 条件。
ClientViewModel.swift
let networkRequest = CustomNetworkRequest(headers: headers, httpMethod: .get, httpBody: nil, parameters: nil, url: url)
let customNetworker = CustomNetworker(urlSession: URLSession(configuration: config))
customNetworker.dataRequest(networkRequest, successHandler: {[weak self] data in
self?.parseData(data)
completion(nil)
}, failureHandler: { [weak self] error in
completion(error)
})
CustomNetworker.swift
final class CustomNetworker {
private let urlSession: URLSession
public init(urlSession: URLSession) {
self.urlSession = urlSession
}
func dataRequest(input parameters here) {
let task = urlSession.dataTask(with: urlRequest) {[weak self] data, response, error in
if let response = response as? HTTPURLResponse , 300...599 ~= response.statusCode,
let data = data,
let error = self?.decodeErrorMessage(data: data, statusCode: response.statusCode) {
failureHandler(error)
} else if let error = error {
failureHandler(error)
} else if let data = data {
successHandler(data)
} else {
failureHandler(error)
}
}
task.resume()
}
}
但是,如果我删除 [weak self]
那么它会按预期工作,它会调用该方法。如何正确解决问题?
let task = urlSession.dataTask(with: urlRequest) {data, response, error in
if let response = response as? HTTPURLResponse , 300...599 ~= response.statusCode,
let data = data,
let error = self.decodeErrorMessage(data: data, statusCode: response.statusCode) {
failureHandler(error)
}
else if let error = error {
failureHandler(error)
} else if let data = data {
successHandler(data)
} else {
failureHandler(error)
)
}
}
task.resume()
decodeErrorMessage 方法
private func decodeErrorMessage(data: Data, statusCode: Int) -> CustomError? {
// not coming into this method
if let errorData = try? JSONDecoder.convertFromSnakeCaseDecoder.decode(CustomServiceError.self, from: data) as CustomServiceError? {
if let errorData = errorData {
return formCustomError(something here)
}
return CustomError.genericError(debugMessage: debugMessage, sourceError: nil)
} else if let errorMessage = StatusCode(rawValue: statusCode) {
let debugMessage = String(data:data, encoding: .utf8)
return formCustomError(something here)
} else {
let debugMessage = String(data:data, encoding: .utf8)
return formCustomError(something here)
}
}
最佳答案
问题是您已将 customNetworker
(CustomNetworker
)设为局部变量,并且一旦该局部变量脱离范围。当 dataRequest(input:)
方法使用 [weak self]
引用时,它表示您不需要 dataRequest(input:)
保持对此 CustomNetworker
实例的强引用。因此,如果没有强引用,CustomNetworker
将被释放。
你有几个选择:
如果您在 dataRequest(input:)
内的闭包中删除了 [weak self]
引用,那么它将保留 CustomNetworker
直到闭包运行。只要您不将此 failureHandler
(和其他闭包)保存为存储属性,就应该没问题。但是不要只是扔进一个[weak self]
因为你在某处读到你应该总是使用弱引用。在需要避免强引用循环的地方使用弱引用,这里似乎不是这种情况。
另一种方法是重构此代码,将此网络请求例程 dataRequest(input:)
移动到某个生命周期更长的对象。
例如,我们通常有一个长期存在的网络管理器对象,它维护 URLSession
并具有所有这些与网络相关的方法。然后,假设您在其他地方保持对该网络管理器实例的强引用,则无需担心该对象在超出范围时被释放。这也使您不必为每个请求传入 URLSession
对象。无论如何,调用者不应处理这些 URLSession
实例。
例如,我经常使用单例网络层(类似于 URLSession.shared
模式):
final class NetworkManager {
static let shared = NetworkManager()
private var session: URLSession = .shared // or create and configure this session as you need; but one session object is all you need
private init() { }
@discardableResult
func performRequest(...) -> URLSessionTask {
...
let task = session.dataTask(...) { [weak self] data, response, error in
...
}
task.resume()
return task
}
}
然后你可以这样做:
NetworkManager.shared.performRequest(...) { [weak self] ... in
...
}
另一种选择是只保留对此 customNetworker
变量的强引用(例如,将其设为属性而不是局部变量)。这将防止 CustomNetworker
对象超出范围并变为 nil
,因为没有更多对它的强引用。
有点不相关,但当您实例化您的 CustomNetworker
对象时,您似乎正在创建一个 URLSession
对象,并且随后永远不会使其无效。这会泄漏。您应该创建一个 URLSession
对象并将其用于所有后续网络请求。
如果您确实创建了多个 URLSession
对象,则必须在使用完后使每个对象失效(例如 finishTasksAndInvalidate
),否则就会泄漏。但是,如果您只有一个 session 可以为所有 future 的网络请求保持事件状态(这是首选),那么就没有必要了。
关于swift - 有或没有[弱 self ],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66051875/
我一直在尝试编写我自己的弱/强指针,但我并不清楚其中的关系。我似乎遇到的所有事情都没有说清楚,而且一个医生经常会反驳另一个医生所说的话。任何人都可以详细解释弱/强指针关系,也许还有图像或代码示例吗?
静态/动态和强/弱类型之间有什么区别? 最佳答案 静态/动态类型涉及何时获取类型信息(在编译时或运行时) 强/弱类型是关于如何严格区分类型(例如,语言是否尝试从字符串到数字进行隐式转换)。 请参阅wi
我有一个非常奇怪的情况。我的服务器当前已关闭并收到 503 http 状态代码。基于如下给定的代码,代码进入 if 条件,但是当我将调试点置于 let error = self?.decodeErro
对于短期运行的操作,避免[weak self]是否可以接受?例如,URLSession 将保留 dataTask(with:completion:) 的闭包: final class ViewCont
我有一个非常奇怪的情况。我的服务器当前已关闭并收到 503 http 状态代码。基于如下给定的代码,代码进入 if 条件,但是当我将调试点置于 let error = self?.decodeErro
假设我有以下情况: Test1.java import java.lang.ref.WeakReference; public class Test1 { public WeakReferen
有没有办法告诉模拟器(我正在使用 Modelsim)当信号不是由任一双向接口(interface)驱动时将信号拉到弱“H”? 例如,如果我有一个 I2C 信号 I2C_SDA 被声明为来自 2 个模块
这是将一些值放入 WeakHashMap 中然后从映射中删除这些值的代码片段。它如何处理分配的内存? import java.util.*; public class WeakHashMap_Main
我正在尝试弄清楚智能指针可以实现什么。 但有一些感觉像是障碍。 普通指针有一个简短的定义 Someclass *p但是智能指针有点长shared_ptr p当您必须处理这些指针的模板(如 vector
这两行代码有区别吗? __weak IBOutlet UITextField *usernameField; @property (weak) IBOutlet UITextField *userna
我最近发现了 WeakHashMap Java 中的数据结构。 但是,我不明白它在不再正常使用时对映射进行垃圾收集是什么意思。数据结构如何知道我将不再在我的程序中使用 key ?如果长时间不引用 ke
我的问题是为什么 weak IBOutletCollection 总是 nil?如果将弱变强,我所有的按钮都在那里,这真的很奇怪。我试图理解苹果的逻辑,我看不出单个按钮和一组按钮在内存管理方面没有区别
我创建一个 WeakHashMap 为 WeakHashMap map = new WeakHashMap(); map.put(emp,"hello"); 其中 emp 是一个 Employee 对
在delphi sydney中,在对象(不是接口(interface))前面设置[weak]会受到惩罚吗?示例: TMyObject = class(Tobject) Private
在delphi sydney中,在对象(不是接口(interface))前面设置[weak]会受到惩罚吗?示例: TMyObject = class(Tobject) Private
众所周知,我们将声明一个可以打破强引用循环的弱委托(delegate)对象: // MyObject.h ... @property (nonatomic, weak) id delegate; ..
我已阅读this article关于Java中不同类型的引用(强引用、软引用、弱引用、幻像引用),但我不太理解。 这些引用类型之间有什么区别?每种类型何时使用? 最佳答案 Java 提供了两种不同类型
我突然想到...我相信弱引用的生命 与该引用的范围(在函数内或全局内)相关。 所以我想知道,只要我将数据处理保持在特定范围内,那么我应该可以使用 weak 与 strong 引用。正确的? 我问的原因
func addAdditionalElement(_ additionalSelectedElementsIDs: [String], startX: CGFloat, containerView:
我想要一个指针,以便我可以判断引用计数何时为 1。本质上,指针的工作方式类似于 weak_ptr,但清理工作需要手动进行。也就是说,程序每隔一段时间就会经历一个指针循环,并检查哪些指针只剩下一个引用。
我是一名优秀的程序员,十分优秀!