Swift

反初始化

本文详细介绍了 Swift 中的反初始化过程,包括反初始化器的语法和实际应用场景。

反初始化器(Deinitializer)是在类实例被释放之前立刻调用的方法。使用 deinit 关键字来定义。

注意:反初始化器只适用于类类型。

反初始化原理

Swift 使用自动引用计数(ARC)来管理内存。当一个实例不再被需要时,ARC 会自动释放其内存。当实例被释放时,反初始化器会被自动调用。

你不能主动调用反初始化器。子类会继承超类的反初始化器,并且在子类反初始化器实现的最后,超类的反初始化器会被自动调用。

反初始化器语法

每个类最多只能有一个反初始化器,且不带任何参数和括号:

deinit {
    // 执行反初始化操作
}

反初始化器实战

反初始化器常用于释放那些不能被 ARC 自动释放的资源,例如文件描述符或自定义的外部资源。

class Bank {
    static var coinsInBank = 10_000
    
    static func distribute(coins numberOfCoinsRequested: Int) -> Int {
        let numberOfCoinsToVend = min(numberOfCoinsRequested, coinsInBank)
        coinsInBank -= numberOfCoinsToVend
        return numberOfCoinsToVend
    }
    
    static func receive(coins: Int) {
        coinsInBank += coins
    }
}

class Player {
    var coinsInPurse: Int
    
    init(coins: Int) {
        coinsInPurse = Bank.distribute(coins: coins)
    }
    
    func win(coins: Int) {
        coinsInPurse += Bank.distribute(coins: coins)
    }
    
    deinit {
        Bank.receive(coins: coinsInPurse)
    }
}

var playerOne: Player? = Player(coins: 100)
print("A new player has joined with \(playerOne!.coinsInPurse) coins")
// 打印 "A new player has joined with 100 coins"
print("There are now \(Bank.coinsInBank) coins left in the bank")
// 打印 "There are now 9900 coins left in the bank"

playerOne!.win(coins: 2_000)
print("PlayerOne won 2000 coins & now has \(playerOne!.coinsInPurse) coins")
// 打印 "PlayerOne won 2000 coins & now has 2100 coins"
print("The bank now only has \(Bank.coinsInBank) coins left")
// 打印 "The bank now only has 7900 coins left"

playerOne = nil
print("PlayerOne has left the game")
// 打印 "PlayerOne has left the game"
print("The bank now has \(Bank.coinsInBank) coins")
// 打印 "The bank now has 10000 coins"

在这个例子中,当 playerOne 被赋值为 nil 时,Player 实例被释放,deinit 被调用,玩家的金币被退还给银行。

在 GitHub 上编辑

上次更新于