![](/img/trans.png)
[英]Not able to pass self (which implements a protocol) to init method of a class instantiation.(Swift)
[英]Passing parameter to method which implements protocol and extends a class in swift
在Objective-C中,您可以通知编译器类型应该是特定类的后代,并且还应遵守协议(例如“ UIViewController * foo = nil”)。
我正在尝试使用Swift做类似的事情,而且看起来这需要使用泛型。 这是我期望的工作方式:
import UIKit
protocol MyProtocol {
var foo: String {get set}
}
class MyViewController: UIViewController, MyProtocol {
var foo: String = ""
}
func doAThing<T: UIViewController where T: MyProtocol>(vc: T) -> T? {
var myViewController: T? = nil
myViewController = MyViewController(nibName: nil, bundle: nil)
return myViewController
}
我得到的错误是:'MyViewController'不能转换为'T'。 我不能将泛型与“具体”,未参数化的类一起使用吗? 我仍在围绕这部分语言进行学习,谢谢您的帮助。
假设您希望MyViewController
是实现MyProtocol
的UIViewController
任何子类,请注意,除了添加与协议相关的任何内容外,实际上没有一种干净的方法可以返回UIViewController
方法。
我认为您正在寻找的是:
protocol MyProtocol {
var foo: String {get set}
}
class MyViewController: UIViewController, MyProtocol {
var foo: String = ""
}
class MyOtherViewController : UIViewController, MyProtocol {
var foo = "My other view controller"
}
func doAThing<T: UIViewController where T: MyProtocol>() -> T? {
return T(nibName: nil, bundle: nil)
}
let myViewController : MyViewController? = doAThing()
let myOtherViewController : MyOtherViewController? = doAThing()
let myProtocol : MyProtocol? = myViewController
由于swift函数的改写只允许根据返回类型而有所不同,并且类型推断可以在它们之间进行选择, doAThing
在这种情况下, doAThing
确实不需要参数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.