class obA: Printable { var description: String { get { return "obA" } }}class obB: Printable { var description: String { get { return "obB" } }}func giveObject() -> obA { return obA() }func giveObject() -> obB { return obB() }var a: obA = giveObject()var b: obB = giveObject()println(a)println(b)
正在调用giveObject的正确变体,一切都很好.当然这只是一个简化的案例,实际上在我的项目中有几十个’giveObject’的重载,所有的返回类型都不同.现在,我想制作一个通用函数来解析所有这些东西.那么,下一步:
func giveGeneric<T>() -> T { return giveObject()}var c: obA = giveGeneric()println(c)
这抱怨了对giveObject的模糊使用.我可以理解错误的来源,但我不知道如何解决它并使用这样的结构……
解决方法 首先只是一个注释.如果giveGeneric的泛型类型只是T,那么它可以是任何东西(String,Int,…).那么在这种情况下,giveObject()应如何反应?
我的意思是,如果你写:
let word : String = giveGeneric()
在内部你的泛型函数调用如下:
let result : String = giveObject() // Ambiguous use of giveObject
我的解决方案
我宣布了一个协议如下:
protocol MyObject { init()}
然后我让你的2个类符合协议
class obA: Printable,MyObject { var description: String { get { return "obA" } } required init() {}}class obB: Printable,MyObject { var description: String { get { return "obB" } } required init() {}}
最后我可以写这个
func giveGeneric<T:MyObject>() -> T { return T()}
现在我可以使用它:
let a1 : obA = giveGeneric()let b1 : obB = giveGeneric()
您可以决定这是您正在寻找的解决方案还是仅仅是一种解决方法.
总结以上是内存溢出为你收集整理的具有返回类型重载的Swift泛型函数调用函数全部内容,希望文章能够帮你解决具有返回类型重载的Swift泛型函数调用函数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)