// Swfit要求我们在创建对象时必须给所有的属性初始化
// 如果没办法保证在构造方法中初始化属性, 可以将属性变为可选类型
var name: String? //= "lnj"
// 注意: 如果是基本类型的属性, 不建议设置为可选类型
// 因为当在构造方法中使用KVC之前, 调用super.init, 系统没办法给基本类型的可选类型属性分配存储空间
// var age: Int? //= 0
var age: Int = -1
计算属性
相当于OC中的readOnly (不完全一样)
最常见的计算属性
注意
var score: Double{
get{
return 99.9
}
}
var rank: Int = -1
var score: Int{
get{
return rank
}
set{
rank = newValue > 80 ? 1 : 100
}
}
属性观察器
延迟存储属性
之外的其他存储属性添加属性观察器willSet
didSet
注意
var score: Double = 0.0{
willSet{
print(score)
// score被修改之前调用
// 调用时会传入一个隐藏参数, newValue , 外界赋值的最新值
print("即将设置新的值 \(newValue)")
}
didSet{ // 相当于OC中重写setter方法
print(score)
// score被修改之后调用
// 调用时会传入一个隐藏参数, oldValue, score以前的值
print("新值以及替代旧值 \(oldValue)")
}
}
override init() {
self.name = ""
self.age = 0
}
// 自定义构造方法 , 必须是init开头
// 一旦自定义了构造方法, 系统默认提供的不带参数的构造方法就会失效
init(name: String, age: Int) {
self.name = name
self.age = age
}
init(dict: [String: NSObject]) {
//self.name = dict["name"] as! String
//self.age = dict["age"] as! Int
super.init()
// 注意: 在Swift的`构造方法`中使用KVC, 必须先调用super.init()
setValuesForKeysWithDictionary(dict)
}
// 看看就行, 不要这样写
var _name: String = ""
var name: String {
set{
print(newValue)
_name = newValue
}
get{
print(_name)
return _name
}
}
/*
lazy var listData: [String] = self.test()
func test() -> [String] {
print("执行了")
return ["lmj", "lnj", "zs"]
}
*/
/*
lazy var listData: [String] = {
()->[String]
in
print("执行了")
return ["lmj", "lnj", "zs"]
}()
*/
/*
lazy var listData = {
()->[String]
in
print("执行了")
return ["lmj", "lnj", "zs"]
}()
*/
// 推荐写法
lazy var listData: [String] = {
print("执行了")
return ["lmj", "lnj", "zs"]
}()
override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
print(listData)
print(listData)
print(listData)
}
override func loadView() {
let tb = UITableView()
tb.dataSource = self
view = tb
}
override func viewDidLoad() {
super.viewDidLoad()
let tb = view as! UITableView
// OC写法 [UITableViewCell class]
// Swift写法 UITableViewCell.self
tb.registerClass(UITableViewCell.self, forCellReuseIdentifier: "myCell")
}
// MAKR: - UITableViewDataSource
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 50
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("myCell", forIndexPath: indexPath)
cell.textLabel?.text = "\(indexPath.row)"
return cell
}
原文:http://www.cnblogs.com/l110/p/5143864.html