13.7 Swift关于便利构造方法“重写”的讨论

        /**

         13.7-关于便利构造方法重写的讨论.mp4

         重写成一个便利构造方法

         

         Swift语言中便利构造方法不能重写。因为它是横向的

         */

        

         

        class Human {

            let name: String

            var age: Int

            init(name: String, age: Int) {

                self.name = name

                self.age = age

            }

            

            convenience init() {

                self.init(name: "", age: 0)

            }

            

        }

        

        class Woman: Human {

            var haveBaby: Bool = false

            

            // 派生类中定义一个构造方法,它跟父类中的某个指定构造方法一样

//            override init(name: String, age: Int) {

//                haveBaby = false

//                super.init(name: name, age: age)

//            }

            

            init(name: String, age: Int, haveBaby: Bool) {

                self.haveBaby = haveBaby

                super.init(name: name, age: age)

            }

            

            // 派生类中用便利构造方法重写父类中的指定构造方法

            //            convenience override init(name: String, age: Int) {

            //                self.init(name: name, age: age, haveBaby: false)

            //            }

            

            // 派生类中用便利构造方法重写父类中的便利构造方法

            // Initializer does not override a designated initializer from its superclass, Swift语言便利构造方法中不存在重写

//            convenience override init() {

//                self.init(name: "", age: 0, haveBaby: false)

//            }

            

            // 这个是当前类中的便利构造方法

            convenience init() {

                self.init(name: "", age: 0, haveBaby: false)

            }


        }

        

        

        var w0 = Woman.init(name: "d", age: 0, haveBaby: true)

        

        var w1 = Woman.init()


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值