Swift和OC的区别:

2017-05-22  本文已影响583人  劉戦軍

Swift与OC之间的关系:

Swift和OC的区别

import UIKit

// swift之构造体
// 学习点: 1.继承结构体与继承协议的区别

protocol A {
    init(a: Int)
}

struct B: A {
    init(a: Int) { // 如果继承构造体协议, 学习点: 协议与代理的区别
                   // 代理需要直接继承协议并遵守协议方可实现方法
                   // 构造体协议只需要继承相应的协议就可以实现协议方法
    }
}

class C : A {
    
    required init(a: Int) {
        // 如果是系统的类继承构造体协议, 会报错
        // 如果是继承构造体协议, 遵守方法并在构造体函数之前加required关键词
    }
}


class ViewController: UIViewController {
//, A {

//    required init(a: Int) {
//        super.init()        // 类构造器不同于协议构造器: 一般实现的类构造器有两种: 1.指定构造器(指定构造器在类中必须至少有一个), 2.便利构造器(没有限制)
//                            // 协议构造器不能直接使用到
//    }
    
//    required init?(coder aDecoder: NSCoder) {
//        fatalError("init(coder:) has not been implemented")
//    }
    
    
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
}

&&& 构造体协议遇到的坑:

错误1

Must call a designated initializer of the superclass 'UIViewController'

因为重载了指定构造器, 所以来自父类的指定构造器并不会被继承.
而 init(coder aDecoder: NSCoder) 方法是来自父类的指定构造器, 因为这个构造器是 required, 必须要实现. 但是因为我们已经重载了 init(), 定义了一个指定构造器, 所以这个方法不会被继承, 要手动覆写, 这就是第一个错误的原因.
我们已经手动覆写了这个方法, 然后, 因为 init() 方法虽然被重载了, 但是并没有调用父类的指定构造器:
指定构造器必须调用它最近父类的指定构造器.
所以我们让这个指定构造器调用 super.init(), 解决了这个问题.
只需要删掉这个 init(coder aDecoder: NSCoder) 方法就可以解决这个错误了.


import UIKit

// 实例方法协议
protocol RandomGeneratable {
    func randomNumber() -> Int
}

struct RandomNumber: RandomGeneratable {
    func randomNumber() -> Int {
        return Int(arc4random()) // 产生一个随机数
    }
}

class TerRandomNumber: RandomGeneratable {
    func randomNumber() -> Int {
        return Int(arc4random())
    }
}


struct Dice {
    var sides: Int
    var randomNumber: RandomGeneratable
    
    func play() -> Int {
        return self.randomNumber.randomNumber() % sides + 1
    }
}


class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        
//        let aDice = Dice(sides: 4, randomNumber: TerRandomNumber())
//        let aDice = Dice(sides: 4, randomNumber: RandomNumber)
        // 区别: 因为不管是结构体还是类, 都继承了 RandomGeneratable 协议,所以在randomNumber: 参数中传入的时候, 传入结构体和类都是可以的
        // 个人补充: 这里还有就是补充了一下结构体和类调用属性时的区别
        // 类调用属性: 需要实例化后的类方法去调用
        // 结构体调用属性: 直接使用结构体调用
        // 感觉类和结构体实例化的时候都是一样的,都是实例化的时候调用属性(个人理解)
        
        
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}
上一篇下一篇

猜你喜欢

热点阅读