Swift   发布时间:2022-03-31  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Swift协议继承和通用函数大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

虑以下游乐场: import Foundation protocol StringInitable { init( String:string ) } class A : StringInitable { var stored:string required init ( String:string ) { stored = String }
虑以下游乐场:
import Foundation

protocol StringInitable {
    init( String:string )
}

class A : StringInitable {
    var stored:string

    required init ( String:string ) {
        stored = String
    }
}

class B : A /*,StringInitable */ {
    var another_stored:string

    required init ( String:string ) {
        another_stored = "B-store"

        super.init(String: String)
    }
}

func maker<T:stringInitable>(String:string) -> T {
    return T(String: String)
}

let instanceA = A(String: "test-maker-A")
let instanceB = B(String: "test-maker-B")

let makerA:A = maker("test-maker-A")
let makerB:B = maker("test-maker-B")

let typeInstanceA = _stdlib_getTypename(instanceA)
let typeMakerA = _stdlib_getTypename(makerA)

let typeInstanceB = _stdlib_getTypename(instanceB)
let typeMakerB = _stdlib_getTypename(makerB)

从结果来看,编译器似乎推断出了正确的类型,但未能调用正确的初始化器.为什么我必须在B类中显式实现StringInitable(通过删除B类定义中的注释来测试)以使通用函数“maker”调用正确的初始化器?

这有点像编译器错误,原因很简单:makerB是B类型的变量,但它被分配了一个A的实例.这应该是不可能的,事实上如果你试图打印,更一般地说是访问,makerB变量的another_stored属性,引发了一个运行时异常,我不希望别的.

是因为如果B是A的子类,则A的实例不能分配给B类型的变量(而相反的情况则可能).

但是,可以将A类型的变量分配给B类型的变量,但仅限于以下条件:

>完成从A到B的显式向下转换(否则编译器应该出错)
> A变量引用的实例实际上是B的一个实例(否则应该引发运行时异常)

请注意,编译器不仅无法调用正确的初始化程序 – 它还调用了另一个类的初始化程序

大佬总结

以上是大佬教程为你收集整理的Swift协议继承和通用函数全部内容,希望文章能够帮你解决Swift协议继承和通用函数所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。