假设我有三个班级:
import Foundation
class A {
init() {
print("A")
}
}
class B {
init() {
print("B")
}
}
class C {
init() {
print("C")
}
}
我想传递一个字符串(" A"," B"或" C")作为函数参数然后,在这个体内function,创建我传递的类的实例。这可能吗?怎么样?
我试过这个(和其他变种),但没有运气:
func test(c:AnyObject){
let _class = c()
//...
}
test(c:A)
[更新]也许这个问题与@Code不同有什么不同但是这个问题已经过时了,语言中有很多变化,人们应该尝试任何建议的解决方案,然后再找到今天起作用的解决方案< / p>
答案 0 :(得分:1)
可以使用基类,我们称之为BaseClass
。需要使用的类将继承自BaseClass
。
然后,在您的函数中,您将传递所需的类型。
以下是演示此技术的代码段:
class BaseClass { }
class A: BaseClass { ... }
class B: BaseClass { ... }
class C: BaseClass { ... }
func test(type: BaseClass.Type) {
let someObject = type.init()
// You can cast the object if required
}
test(type: A.self) // creates an object of class A
test(type: B.self) // creates an object of class B
编辑: 如果您确实需要一个字符串来投射您的类型,您可能会在调用test
之前考虑做一些工作。获取切换案例中的类型然后将其传递给test
应该这样做。
编辑它也适用于协议,只要它定义了您需要的初始值设定项,以及必须公开的每个函数:
protocol SomeProtocol: class {
init()
func someFunction()
}
class A {
required init() {
print("A")
}
}
extension A: SomeProtocol {
func someFunction() {
print("Some function of A")
}
}
class B {
required init() {
print("B")
}
}
extension B: SomeProtocol {
func someFunction() {
print("Some function of B")
}
}
class C {
required init() {
print("C")
}
}
extension C: SomeProtocol {
func someFunction() {
print("Some function of C")
}
}
func test(someType: SomeProtocol.Type) {
let someObject: SomeProtocol = someType.init()
someObject.someFunction()
}
test(someType: A.self) // creates an object of class A
test(someType: B.self) // creates an object of class B