#available()
函数来检查API函数的可用性
// 判断当前版本是否 iOS8.0+,OSX10.10+以及以其他平台 if #available(iOS 8.0, OSX 10.10, *) { // 当版本匹配时 } else { //当版本不匹配时 } 也可以放在方法前面, 使其方法在某个版本可用 // iOS8.0+,OSX10.10+以及以其他平台可用 @available(iOS 8.0, OSX 10.10, *) func startUserActivity() -> NSUserActivity { }
新的guard语法:
这个新的语法允许你在一个代码周期中构建一个提前的退出点, 避免了大量的if 判断
如果 a >= b 就会进入else直接退出 guard a < b else { return }
optional
修饰 protocol时方法不用必须实现
强制展开(!)
如果对一个nil的optional 的变量进行强制展开(就是加上!), 会出现运行时错误, 所以如果对变量进行强制展开必须要保证Optional的变量不为nil
使用问号(?
)来替代原来的叹号(!
)
if optionalChaining.string?.characters.count > 0 { }
只有optionalChaining.string不为nil的适合才能访问characters
convenience
其内部一定要调用其同类的init方法完成初始化
注意: 子类不能重写这个方法或从子类中以super的方式调用, 子类一旦重写这个方法调用的init方法就会调用这个方法, 所以不需要重写
用法: 如果你想某些子类一定要调用某个初始化方法, 那么就可以在父类中加上一个convenience初始化方法, 这样子类每次创建对象的同时都会去调用这个init方法
如果想强制子类一定调用这个方法, 可以结合required 修饰符在所调用的init方法前面加上required
required修饰符的使用规则
required
修饰符只能用于修饰类初始化方法。- 当子类含有异于父类的初始化方法时(初始化方法参数类型和数量异于父类),子类必须要实现父类的
required
初始化方法,并且也要使用required
修饰符而不是override
。 - 当子类没有初始化方法时,可以不用实现父类的
required
初始化方法。注意: 子类如果集成父类一定要在重写父类init方法时候调用[super init], swift强制这么做
protocol SomeProtocol {
init(someParameter: Int)
}
class SomeClass: SomeProtocol { required init(someParameter: Int) { // 这里是构造器的实现部分 } }
mutating
修饰方法能修改同实例属性值
协议 方法前面加上mutating 表示遵守协议的结构体 / 枚举能修改同实例属性
结构体/ 枚举中 方法要修改同实例属性需要在方法前面加上mutating, 表示你可以修改同实例属性
enum OnOffSwitch: Togglable { case Off, On mutating func toggle() { switch self { case Off: self = On case On: self = Off } } } var lightSwitch = OnOffSwitch.Off lightSwitch.toggle() // lightSwitch 现在的值为 .On
typealias type
// 对原有类型, 声明一个新名称, 相当于以前的typedef
@testable
当你的应用程序包含单元测试 target 时,为了测试,测试模块需要访问应用程序模块中的代码。默认情况下只有public
级别的实体才可以被其他模块访问。然而,如果在导入应用程序模块的语句前使用 @testable
特性,然后在允许测试的编译设置(Build Options -> Enable Testability
)下编译这个应用程序模块,单元测试 target 就可以访问应用程序模块中所有 internal
级别的实体。
fallthrough
用在swich case 中表示, 上下case 可以一起执行
__FILE__
当前文件路径
Defer 语句
defer 语句用于在退出当前作用域之前执行代码。
inout
传进去的参数直接可以修改, 就像传进去是地址, 地址对应的值被修改,调用的时候在变量前面加上&
deinit
析构函数, 相当于oc中dealloc
is
一般做判断使用
swift3.0
fileprivate 与 private
fileprivate 就是以前的 private 整个文件都能访问
private 现在是只能在当前class内部访问
如果在extention访问private的变量 会报variable is inaccessible due to 'private' protection level
open 与 public
现在swift 的变量作用域修饰符有如下几种(从高到低): open, public, fileprivate, private
open: 以前的public, 所有地方都能访问, 并且能重写, 能继承
public: 只能访问在module内部重写, 能访问. 继承
inout
inout作为函数声明时,引用传值的关键字。但是在调用的时候引用的是地址,所以在引用的时候要加上 &
override func viewDidLoad() { super.viewDidLoad() var a = 10 var b = 20 var _ = test(a: &a, b: &b); } func test(a: inout Int, b: inout Int) -> Int{ return a + b }
nonmutating
在声明值类型的实例为不可变变量,即let时,是不可以修改任何它内部的变量值的
struct TTTTStruct { var name: String { get { return "123456" } nonmutating set { print(newValue) } } } class TTClass2: TTClass { override func ghjk() { let sttttt = TTTTStruct() sttttt.name = "4546" name = "1234" print(name) } }
associatedtype
associatedtype
用于protocol
中,associatedtype
类型是在protocol
中代指一个确定类型并要求该类型实现指定方法。