首页投稿(暂停使用,暂停投稿)

Swift3 新特性

2016-06-15  本文已影响1286人  kenny肉桂

看了一下刚出的 Session 406,简单记录一下关于 Swift3.0相比2.2的改动. 能力有限,若有谬误,欢迎指正 .

简化的 API

Swift 2.2

var array:Array = [1,2]

array.appendContentsOf([2,3,4])
array.insert(1, atIndex: 0)

var url = NSURL(string: "randomLoacation")!

if url.fileURL {}
var x = url.URLByAppendingPathComponent("file.txt")

Swift 3.0

//Swift.Array
var array:Array = [1,2]

array.append(contentsOf: [2,3,4])
array.insert(1, at: 0) //index没有什么特定信息,只是重复

//Foudation.NSURL
var url = NSURL(string: "randomLoacation")!
if url.isFileURL {} //意思更明确
var x = url.appendingPathComponent("file.txt")

一致的函数参数标签

原来2.2中, 第一个参数标签可以省略.类似这样:


func myFunction(a: Int , b: Int , c: Int){

}

myFunction(42, b: 57, c: 39)

在 3.0 中,上面的用法会报错. 需要显式写出标签,类似这样:


func myFunction(a: Int , b: Int , c: Int){
    
}

myFunction(a: 10, b: 10, c: 10)

当然,如果实在不想写,可以在声明的时候使用 _ .


func myFunction(_ a: Int , b: Int , c: Int){
    
}

myFunction(10, b: 10, c: 10)

移动 Where 语句到函数声明的结尾

在 Swift2.2中,泛型约束语句Where需要放到泛型的<>中.

func anyCommon<T: SequenceType, U: SequenceType
    where T.Generator.Element : Equatable,
    T.Generator.Element == U.Generator.Element>(lhs: T, rhs: U) -> Bool{
    print("here")
    return true;

}

在 Swift3.0中,将其提取到声明之后:
代码是参考的 Session 中的代码,但是本人用 Xcode8.0的 Playground 报错.但是主旨不会错,就是将Where语句提取出来.

func anyCommons<T: Sequence, U: Sequence>(lhs: T, rhs: U) -> Bool
    where T.Element: Equatable,T.Element == U.Element
{
    print("here")
    return true;
    
}

结果未使用警告的方法

对于一个没有使用的函数返回值(或者自定义的变量值),编译器都会给你一个警告.因为既然你认为有返回值, 而你却没有使用.这可能就是你忘记了.这种操作可能会造成你编码的 bug

   func plusOne(_ a : Int) ->Int{
            print(a)
            return a+1
        }
        
        plusOne(3) //得到警告 Result of call to 'plusOne' is unused
        
        

但是一些情况下.我们确实不需要用到这个返回值,而且仅仅是为了函数的一个副作用( side effect) 而去调用函数. 例如,上面代码中的print(a).这就是我调用函数的目的.
为了消除警告,可以使用如下方式:

        
        func plusOne(_ a : Int) ->Int{
            print(a)
            return a+1
        }
        
        _ =  plusOne(3)

或者使用标记 @discardableResult:

        @discardableResult
        func plusOne(_ a : Int) ->Int{
            print(a)
            return a+1
        }
        
        plusOne(3)

索引集合

let collection = ["a","b","c","d"]

var i = collection.startIndex

在 Swift 2.2 中

swift 2 : var next = i.successor()

在 Swift 3.0 中

var next = collection.index(after: 2)

浮点型和数值型

用 PI 来举个例子:
Swift 2.2

let v = 2 * Float(M_PI)

而在 Swift3.0中

let v = 2 * Float.pi

如果第一个操作数是浮点数,还可以这样写:

let anotherV = 2.0 * .pi / 180

隐式解包可选

在 Swift2.2中

func f(value: Int!){
    let x = value + 1 // x 是 Int 类型 - 强制解包
    let y = value     // y 是 Int!

}

在 Swift 3.0 中

func f(value: Int!){
    let x = value + 1 // x 是 Int 类型 - 强制解包
    let y = value     // y 是 Int?

}

具体参考:
SE-0054

一些细节的增强

移除的功能

  1. 函数柯里化Currying介绍
  2. 函数参数中的 var 详细介绍
  3. 去掉 ++-- 操作符
  4. C 风格的for循环
  5. 通过元组的形式传递函数参数列表 .详细介绍

对第5条做一个说明:
在 swift 2.2 中,我们可以:

let param = (20,"kenny","male")

func personInfo(age: Int ,_ name: String ,_ gender: String){

}

personInfo(param)

//也可以不省略标签

let param = (age:20, name:"kenny", gender:"male")

func personInfo(age age: Int , name: String , gender: String){

}

personInfo(param)

这个语法在 Swift3.0中被去掉了.原因是这么传递,可能会和有一个元组类型参数的函数混淆.

参考 : WWDC 2016 Session 402 What's new in Swift

上一篇下一篇

猜你喜欢

热点阅读