所以我有这段代码,我正在尝试为请求创建一个任务处理程序。但是在某些情况下,请求没有得到响应的模型,因此我不希望它处理任何数据。很难解释,但代码如下所示:
class UserTask<T: Codable>: ExecuteProtocol {
let userType: UserRequests
init(userType: UserRequests) {
self.userType = userType
}
var request: URLRequest {
return userType.build
}
public func run(completion: @escaping ((Response<T, NAError>) ->())) {
executeRequest(request: request) { (response) in
switch response {
case .success(let data):
completion(NADecoder<T>.decode(data: data).model)
break
case .failure(let error):
completion(.failure(error))
break
}
}
}
}
class UserTask: ExecuteProtocol {
let userType: UserRequests
init(userType: UserRequests) {
self.userType = userType
}
var request: URLRequest {
return userType.build
}
public func run(completion: @escaping ((Response<Any?, NAError>) ->())) {
executeRequest(request: request) { (response) in
switch response {
case .success(let data):
completion(.success(nil))
break
case .failure(let error):
completion(.failure(error))
break
}
}
}
}
这当然是说Invalid redeclaration of 'UserTask'
但是我能以任何顺利的方式做到这一点吗?我尝试将 Codable 设置为可选,然后将其解开。但是,由于我想将其类型保留在可解码的目的中,因此它似乎不起作用。
有什么建议吗?
无需为同一功能创建多个类。您只需对单个类进行一些更改即可支持您的两个用例。
而不是将泛型<T>
添加到class UserTask
,而是将其添加到方法run(completion:)
,即
class UserTask: ExecuteProtocol {
let userType: UserRequests
init(userType: UserRequests) {
self.userType = userType
}
var request: URLRequest {
return userType.build
}
public func run<T: Codable>(type: T.Type, completion: @escaping ((Response<T?, NAError>) ->())) {
//your code here...
}
}
这样称呼它,
task.run(type: YourType.self) { (response) in
//add your code here...
}