我正在尝试用swift来处理一些Euler问题。
我最初尝试使用操场,但发现它非常慢,所以我制作了一个简单的单视图应用程序,可以在模拟器中为我运行它们。下面是我的例子:
我做这件事的方法是我创建了一个名为ProblemClass
的客户类,然后为从该类继承的每个问题创建一个新类。之后,我所要做的就是重写ProblemClass
中的函数,然后视图控制器只加载从Problem1
继承的ProblemClass
类中的所有信息。
当它转到从Problem1
加载的视图(或任何其他问题)时,它通过在segue期间设置currentProblem
变量来获取详细信息。见下文
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
let destination = segue.destination as! ProblemVC
let cell = sender as! ProblemsTVCell
let label = cell.label!
switch label.text! {
case "Problem 1":
destination.currentProblem = Problem1()
case "Problem 2":
destination.currentProblem = Problem2()
case "Problem 3":
destination.currentProblem = Problem3()
case "Problem 4":
destination.currentProblem = Problem4()
default:
break
}
}
有没有办法用一个字符串来分配问题,这样我就不用做成百上千个这样的案例了?我不知道它会是什么样子,而且一直试图用谷歌返回关于“选择器”的答案。我不知道它到底是什么样子,但在我的脑海里我在想这样的事情。
destination.currentProblem = Class(name: "Problem4")
如果我的要求不清楚,请告诉我,我会尽量解释清楚的。
提前谢谢你!
---编辑---
从下面选择的答案中添加我的解决方案。
所以我将prepare函数改为:
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
let destination = segue.destination as! ProblemVC
let cell = sender as! ProblemsTVCell
let label = cell.label!
let problemName = label.text!.replacingOccurrences(of: " ", with: "")
let problemClass = NSClassFromString("Project_Euler.\(problemName)")! as! ProblemClass.Type
destination.currentProblem = problemClass.init()
}
为了在我的课堂上得到
init()
,我让我的课看起来像这样:class ProblemClass {
required init() {
return
}
func title() -> String {
return "Title"
}
func problem() -> String {
return "Problem #"
}
func question() -> [String] {
return ["No Question Yet"]
}
func answer() -> [String] {
return ["No Answer Code Entered Yet"]
}
}
最佳答案
也许:
let problemNumber: Int = 1
var className = "AppName.Problem\(problemNumber)"
let problemClass = NSClassFromString(className) as! Problem.Type
destination.currentProblem = problemClass