从此刻开始拥抱 Swift 3.0

SwiftGG 翻译组
原文链接
作者: Vic Chan
若有问题或者错误请联系我:[email protected]

API is shortened

++ / --

Swift 2.2 的时候对 a ++ 或者 a -- 已经给出warning 提示将在Swift3.0中将废除。

不嫌麻烦可以重载运算符来实现

postfix operator ++

postfix func ++(a: Int) -> Int {
    return a + 1
}

a++ // 11

更彻底点可以考虑使用引用,加上 inout

函数中的 var

为了修改函数参数,添加 var 关键字

func setName(var name: String) {
    
}

现已删除

func setName(name: String, na: String) {
    name += na
    
    
}

无法再修改参数, inout可以

Repeat

var i = 0

repeat {

    print("Hello")
    i = i + 1
} while( i < 10 )

替代 do while 感觉主要是避免与 do catch冲突

每个函数的参数标签一致:

func getPerson(name: String, age: Int) {
    //....
}
  • Swift 2.2 中:
getPerson("Vic", age: 10)
  • Swift 3 中:
getPerson(name: "Vic", age: 10)

除非手动添加 _ 否则参数名会保持一致性原则

一直在改变的Selector

Swift 3:

button.addTarget(Responder(), action: #selector(Responder.tap), for: .touchUpInside)

将确定selector的过程从运行时移到了编译时。

KVO

#KeyPath() 形式类似于Selector

只适用于非Objc对象。

class Object : NSObject {
    
    @objc var name = ""
    var age = 0
    init(name: String, age: Int) {
        self.name = name
        self.age = age
    }
}

let sss = p.value(forKey: #keyPath(Object.age))

@discardableResult

如果未使用函数返回值,在没有 @discardableResult的前提下,会报错

fileprivate: 让私有变得更具体

之前 Swift 2.2 及之前版本,private 并不是严格的私有,在同一文件,依然可以访问到.

为了严格化, Swift3.0 中 设置了 fileprivate 来取代之前 private 的作用。 而新的 private 则是严格的私有权限。

fileprivate func sss() {
    
}

private func aaa() {
    
}

private 变得更加严格。

class Access {
    
    private var a = 0
    private func getA() -> Int {
        return a;
    }
    
    fileprivate func desc() {
        print("\(a) time")
    }
    
}

let p = Access()
// 报错,提示getA() 是私有成员
p.getA()

上述p只能访问desc()

  • Swift现有 访问级别
公开(public)
内部(internal)
文件外私有(fileprivate)
私有(private)

inout 变了

之前的写法

func saaa(inout a: Int) {
    
}

现在作为一种修饰符而存在

func saaa(a: inout Int) {
    
}

关联类型声明由 typealias 变为 associatedtype

先说下 Swift的关联类型

Swift支持泛型,class struct enum 都支持泛型, 而协议呢?

Swift是一门面向协议的语言。

protocol hahah {
    
}

Protocols do not allow generic parameters, use associated types instead

泛型协议

protocol Haha {
    associatedtype Element
    
    var s: Int { get set }
    
    func getElement() -> Element

}

在 Swift 3 中, 不再允许 typealias 来构造泛型。

告别C经典循环方式

for (int i = 0; i < 10; i ++)
  • Swift Loop Style
// i is not mutable
for i in 1...3 {
   // i += 1   
    print(i)

}

// i is mutable
for var i in 1...10 {   
    i += 1
    print(i)
}

// 枚举
(1...3).forEach{i in
    print(i)
}

告别柯里化函数

Xcode 7.3 的 Swift 2.2 版本中已有提示柯里化函数不再使用。

func add(a: Int)(b: Int) -> Int {
    return a + b
}

当然函数式编程依然完美解决

func add(_ a: Int) -> (Int)-> Int {
    return { b in return a + b }
}
var s = add(10)(20)

你可能感兴趣的:(从此刻开始拥抱 Swift 3.0)