对 swift 中的初始化感到困惑
confusion over initialisation in swift
根据"Swift programming language 2.1",如果子class为其所有属性提供默认值,则子class自动继承其所有超class的指定初始化器和便利初始化器。所以对于下面的代码,class ShoppingListItem
应该从它的 superclass、RecipeIngredient
继承三个初始化器,即
//1
convenience init() {
self.init(name: "[unnamed]")
}
//2
convenience init(name: String){
self.init(name: name, quantity: 1)
}
//3
init(name: String, quantity: Int){
self.quantity = quantity
super.init(name: name)
}
如果我想创建一个 ShoppingListItem 的实例,我会写
let ingredientThree = ShoppingListItem(name: "apple", quantity: 10)
这将调用 init(name: String, quantity: Int){}
,但在此初始化程序中,有一个对 super.init(name: name)
的调用,这就是我卡住的地方。当初始化过程达到 super.init(name: name)
时会发生什么?它会调用 ShoppingListItem
的 superclass 的 init(name: String){}
初始化程序吗?或者不是吗?这里到底发生了什么?有人可以向我解释一下吗?在此先感谢您的帮助!
实际代码:
class Food {
var name: String
init(name: String){
self.name = name
}
convenience init() {
self.init(name: "[unnamed]")
}
}
class RecipeIngredient: Food{
var quantity: Int
init(name: String, quantity: Int){
self.quantity = quantity
super.init(name: name)
}
override convenience init(name: String){
self.init(name: name, quantity: 1)
}
}
class ShoppingListItem: RecipeIngredient {
var purchased = false
var description: String {
var output = "\(quantity) X \(name)"
output += purchased ? " ✔" : " ✘"
return output
}
}
图表来自 Swift 编程语言 2.1
我将您的代码放到了 playground 中并添加了一些打印件。这是发生了什么:
- RecipeIngredient.init(字符串,整数)
- Food.init
顺便说一句,你问它是否会调用 ShoppingListItem 的 superclass 的 init(name: String){} 初始化程序。
答案是否定的。你用过
let ingredientThree = RecipeIngredient(name: "apple", quantity: 10)
这与 ShoppingListItem 无关。
一般来说,如果您有 class 继承 Class1 <- Class2 <- Class3。然后你实例化 Class2,然后 Class3 永远不会发挥作用。
class Food {
var name: String
init(name: String){
print("Food.init")
self.name = name
}
convenience init() {
self.init(name: "[unnamed]")
}
}
class RecipeIngredient: Food{
var quantity: Int
init(name: String, quantity: Int){
print("RecipeIngredient.init(String, Int)")
self.quantity = quantity
super.init(name: name)
}
override convenience init(name: String){
self.init(name: name, quantity: 1)
}
}
class ShoppingListItem: RecipeIngredient {
var purchased = false
var description: String {
var output = "\(quantity) X \(name)"
output += purchased ? " ✔" : " ✘"
return output
}
}
let ingredientThree = RecipeIngredient(name: "apple", quantity: 10)
根据"Swift programming language 2.1",如果子class为其所有属性提供默认值,则子class自动继承其所有超class的指定初始化器和便利初始化器。所以对于下面的代码,class ShoppingListItem
应该从它的 superclass、RecipeIngredient
继承三个初始化器,即
//1
convenience init() {
self.init(name: "[unnamed]")
}
//2
convenience init(name: String){
self.init(name: name, quantity: 1)
}
//3
init(name: String, quantity: Int){
self.quantity = quantity
super.init(name: name)
}
如果我想创建一个 ShoppingListItem 的实例,我会写
let ingredientThree = ShoppingListItem(name: "apple", quantity: 10)
这将调用 init(name: String, quantity: Int){}
,但在此初始化程序中,有一个对 super.init(name: name)
的调用,这就是我卡住的地方。当初始化过程达到 super.init(name: name)
时会发生什么?它会调用 ShoppingListItem
的 superclass 的 init(name: String){}
初始化程序吗?或者不是吗?这里到底发生了什么?有人可以向我解释一下吗?在此先感谢您的帮助!
实际代码:
class Food {
var name: String
init(name: String){
self.name = name
}
convenience init() {
self.init(name: "[unnamed]")
}
}
class RecipeIngredient: Food{
var quantity: Int
init(name: String, quantity: Int){
self.quantity = quantity
super.init(name: name)
}
override convenience init(name: String){
self.init(name: name, quantity: 1)
}
}
class ShoppingListItem: RecipeIngredient {
var purchased = false
var description: String {
var output = "\(quantity) X \(name)"
output += purchased ? " ✔" : " ✘"
return output
}
}
图表来自 Swift 编程语言 2.1
我将您的代码放到了 playground 中并添加了一些打印件。这是发生了什么:
- RecipeIngredient.init(字符串,整数)
- Food.init
顺便说一句,你问它是否会调用 ShoppingListItem 的 superclass 的 init(name: String){} 初始化程序。
答案是否定的。你用过
let ingredientThree = RecipeIngredient(name: "apple", quantity: 10)
这与 ShoppingListItem 无关。
一般来说,如果您有 class 继承 Class1 <- Class2 <- Class3。然后你实例化 Class2,然后 Class3 永远不会发挥作用。
class Food {
var name: String
init(name: String){
print("Food.init")
self.name = name
}
convenience init() {
self.init(name: "[unnamed]")
}
}
class RecipeIngredient: Food{
var quantity: Int
init(name: String, quantity: Int){
print("RecipeIngredient.init(String, Int)")
self.quantity = quantity
super.init(name: name)
}
override convenience init(name: String){
self.init(name: name, quantity: 1)
}
}
class ShoppingListItem: RecipeIngredient {
var purchased = false
var description: String {
var output = "\(quantity) X \(name)"
output += purchased ? " ✔" : " ✘"
return output
}
}
let ingredientThree = RecipeIngredient(name: "apple", quantity: 10)