具有返回类型重载的Swift泛型函数调用函数
发布时间:2020-12-14 04:42:22 所属栏目:百科 来源:网络整理
导读:只是一个简单的问题.我有以下代码,工作得很好: class obA: Printable { var description: String { get { return "obA" } }}class obB: Printable { var description: String { get { return "obB" } }}func giveObject() - obA { return obA() }func giveO
只是一个简单的问题.我有以下代码,工作得很好:
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() 您可以决定这是您正在寻找的解决方案还是仅仅是一种解决方法. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |