- 定义类
class Dog {
let name = "wang wang"
var age = 0
func talk(){
print("我是一只单身狗")
}
}
使用类如下:
let dog=Dog()
dog.age = 10
dog.talk()
可以看到,swift相比ObjC回归正常了,类是class而不是interface了。类里的成员变量或常量就是类的属性,不用像ObjC那样以@property开头了。定义属性时可以直接赋初始值。定义成员函数与定义全局函数在语法上并没有半毛区别。
创建类的实例时,其语法跟ObjC之外的语言一致了,通过“()”里的参数对应某个构造方法。我们没有为上面的类提供额外的构造方法,所以使用了默认的构造方法(没有任何参数的那个)。不论是使用属性还是调用成员(方法)函数,都用点即可。
类不必有父类,这点与ObjC不同,ObjC的类必须直接或间接从NSObject派生。
- 构造方法
构造方法的名字都叫“init”。
class Dog {
let name:String
var age:Int
init(){
self.name = "wang wang"
self.age = 10
}
init(name:String,age:Int){
self.name = name
self.age = age
}
func talk(){
print("我是一只单身狗")
}
}
增加了2个构造方法,把属性的初始化移到构造方法中了,这跟上一个例子的初始化方式实质上没有区别。注意常量属性只能在构造方法中初始化一次。到底是使用哪个构造方法来初始化,这得看在创建类实例时传的参数。每个属性必须都要进行初始化。可以在声明它时,也可以在构造方法中。
self代表实例自身,相当于其它语言里的this。
- 析构方法
与构造方法对应,析构方法叫做“deinit”。在实例要被销毁前被调用。里面可以做一些清理工作。析构方法只能有一个且没有参数。例如:
class Dog {
let name:String
var age:Int
init(){
self.name = "wang wang"
self.age = 10
}
init(name:String,age:Int){
self.name = name
self.age = age
}
//析构方法,因为不需要参数,因此连“()”都不能带了
deinit{
print("看到这句话,就是我的死期,永别了世界")
}
func talk(){
print("我是一只单身狗")
}
}
- 继承
//撸码狗
class CodingDog : Dog{
var codingYears:Double
//构造方法
init(name:String,age:Int,codingYears:Double){
self.codingYears=codingYears
super.init(name: name,age: age)
}
//重写了父类的方法
override func talk(){
print("我是一只撸码狗")
}
}
冒号后面写父类的名字,就是继承了。继承就是有了它爹的属性和方法。构造方法中必须调用它爹的某个构造方法。super就代表它爹。并且必须先初始化了儿子的属性后才能调用爹的构造方法,这样规定是为了避免坑爹。
儿写重写了爹的方法,儿子必须标明override。如果没有,被视为语法错误。而如果在一个不是重写的方法上用了,也不允许。很好!避免了很多混乱。