看了斯坦福老头的课,真心觉得,我的中文怎么也变的这么垃圾了。是关于iOS8的课程,用swift写的,一个计算器应用的制作,看看人家的课,再看看咱们学校的课(不过垃圾学校,纯粹觉得大学浪费了),废话啊,废话,继续废话。那个老头的代码有些我给省略了,不知道会出现什么问题,反正我是没有发现,如果你发现了,请告诉我。还有就是这个计算器的具体操作步骤是,你先4-> 回车-> 5-> 回车 ->乘号 显示计算结果20
首先是界面的搭建,就是0-9一共10个按钮,然后加减乘除四个操作按键,以及,一个回车键(用来将所输入的数存放在栈中,反正老头是这样说的,他把输入进去的数存放到了一个数组中了var operandStack = Array<Double>(),还有就是一个用来显示输入的数以及输入结果的label了。这些都是在故事板中进行的(当然除了那个数组),然后将label与代码关联
@IBOutlet weak var resultLabel: UILabel!
//事实上,在这里指明类型被认为是不好的书写方式,如果可以推断出类型 ,你就应该让编译器自己去推断
//var isStart :Bool = false
var isStart = false //用户是不是已经输入,那个老外用了一长串的字符userIsInTheMiddleOfTypingANumber
将0-9这10个数的点击事件与代码关联
@IBAction func buttonTap(sender: UIButton) {
let digit = sender.titleLabel?.text// 注意这个digit是一个可选值(opentional),就是你点击的按钮上的数字,
if isStart{
resultLabel.text = resultLabel.text! + digit! //可选值是不可以拼接字符串的,所以在这个地方,需要进行解包
}else{
resultLabel.text = digit//用户第一次点(我这样理解的),结果框显示你按的那个数
isStart = true//这个是说用户已经开始输入了
}
}
var operandStack = Array<Double>()
//这个变量是一个内部的栈,去存储你输入的这些数,他的类型是一个数组,这个数组里存放的是Double的变量,注意在这个地方要初始化,(我们不能使用没有经过初始化的,会报错)
@IBAction func enter() {
isStart = false //因为我们在点完enter的时候,需要将刚才输入的数放到栈里,并且输第二个数,所以需要将这个布尔值设为false
// var value = (resultLabel.text! as NSString).doubleValue
operandStack.append(resultValue)
println("operandStack: \(operandStack)")
}
//计算型属性
var resultValue:Double{
get{
return NSNumberFormatter().numberFromString(resultLabel.text!)!.doubleValue
}
set{
resultLabel.text = "\(newValue)" //newValue是系统的,就是想要设置的那个值 2将double类型转换为字符串
// isStart = false// 这句话写在这不知道是什么意思,该怎么理解呢
}
}
@IBAction func operate(sender: UIButton) {
let operation = sender.currentTitle!
switch operation{
// case "??" : performOperation { $1 * $2 }
case "??": performOperation { $0 * $1} //这个地方,这地方真心坑,$0 * $1,我还以为传进入随便两个数就行了呢,那老头对这段代码不断的简化简化,才写成了这样,明天把简化的过程单独整理出来(明日复明日啊)
case "?" : performOperation { $1 / $0 }
case "?" : performOperation { $1 - $0 }
case "?" : performOperation { $1 + $0 }
default:break
}
}
func performOperation(operation:(Double,Double)->Double){//函数的参数是一个函数
if operandStack.count >= 2{
resultValue = operation(operandStack.removeLast() , operandStack.removeLast())//operandStack.removeLast()难道说,这个方法删除并返回了最后一个数?
}
}
// func multipy(op1:Double,op2:Double)->Double{
//
// return op1 * op2
// }