所以我有这段代码,我试图为请求创建一个任务处理程序。但在某些情况下,请求没有得到响应的模型,因此我不希望它处理任何数据。很难解释,但代码如下:
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'
,但我能用任何平滑的方式做到这一点吗?我试着让编码成为可选,然后拆开它。但由于我想保持它的类型在可解码的目的,它似乎不起作用。有什么建议吗?
最佳答案
不需要为同一功能创建多个类。您只需要对单个类进行一些更改,以支持这两个用例。
不要在<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...
}
关于swift - 我可以像使用函数一样重复类吗,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/57755966/