
as :类型一致或者子类
仅当一个值的类型在运行时(runtime)和as模式右边的指定类型一致 - 或者是该类型的子类 - 的情况下,才会匹配这个值。如果匹配成功,被匹配的值的类型被转换成as
模式左边指定的模式。
class Animal {}
class Dog: Animal {} let d = Dog()
d as Animal
as! 父类强转子类
class Animal {}
class Dog: Animal {} let a: Animal = Dog()
a as! Dog
不加!编译会报错
as? 转换失败返回nil
class Animal {}
class Dog: Animal {}
class Cat: Animal {} let animal: Animal = Cat()
animal as! Dog
animal as? Dog
animal as! Dog 编译会报错 as?就是对的
声明时候的!跟?的区别
var amiteLbl :UILabel? self.amiteLbl = UILabel(frame:CGRectMake(,,,))
self.amiteLbl!.text = "I love mixbox"
self.view?.addSubview(self.amiteLbl)
由于amiteLbl是可选变量,所以可能有值,也可能为nil。
使用self.amiteLbl!
是明确声明此时self.amiteLbl
里一定有值,无论什么情况都调用后面的.text赋值方法。
而使用self.view?
是声明此时并不确定self.view里是否有值,所以只在view有值时调用后面.addSubview
方法。
这样做的目的一是让代码更明确, 二是给编译器提供更多线索,在编译时发现更多潜在错误。
Swift显然是一门非常明确,需要开发者先想清楚再编程的语言,秉承了Apple一贯的作风:)