带有泛型参数类型的Swift函数

4

我正在寻找一种简单方便的方法来实现一个可以接受可以转换为字符串类型的所有类型的函数,例如:myFunc("This string")myFunc(2)myFunc(true)。我认为这可以通过泛型参数来实现,并尝试了类似于以下内容的代码:

func myFunc<T: StringLiteralConvertible>(param: T? = nil) -> String {
   // ...
   return "\(param)"
}

但是到目前为止,我还没有成功。


你的测试输出是什么? - akohout
问题在于该方法不接受 Int 和 Bool 作为参数。 - dibi
你想为整数和布尔参数返回字符串吗?比如muFunc(2)将返回"Two",而myFunc(true)将返回"true"。 - Vijay
1个回答

1
使用 CustomStringConvertible 而不是 StringLiteralConvertible:
func myFunc<T: CustomStringConvertible>(param: T? = nil) -> String {
    // ...
    return "\(param)"
}

myFunc("Grimxn") // Optional("Grimxn")
myFunc(12) // Optional(12)
myFunc(true) // Optional(true)
myFunc(-1.234) // Optional(-1.234)
//myFunc() // doesn't work. Compiler can't infer T

这些将会给出 Optionals,因为你将它们转换为 T? 以允许你的 nil 默认值。去掉默认值(它无效 - nil 不能暗示 T),就可以摆脱 Optional
func myFunc<T: CustomStringConvertible>(param: T) -> String {
    // ...
    return "\(param)"
}

myFunc("Grimxn") // "Grimxn"
myFunc(12) // "12"
myFunc(true) // "true"
myFunc(-1.234) // "-1.234"
//myFunc((1,2)) // doesn't compile
myFunc(NSDate()) // "2015-10-26 10:44:49 +0000"

谢谢您的建议,但这样做不会使类型安全变得无用吗?因为文档中说CustomStringConvertible:“对于任何类型的实例都可以工作,如果该实例恰好是CustomStringConvertible,则返回其描述。” - dibi
基本上,继承自NSObject的所有东西都可以传递。 - dibi
这是安全的,因为任何符合 CustomStringConvertible 的类型都可以传递,否则代码就无法编译。 - vadian

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接