swift3新特性

2017-02-13  本文已影响19人  天蚕

1、废除++--运算用+=-=替换
2、废除传统的for循环写法替换如下

//正常序列
for i in 0 ... 8
{

}

//反转序列
for i in (0...8).reversed() {
    
}

//输出10 9 8 7 6 5 4 3 2 1
for i in stride(from: 10, to: 0, by: -1)
{
    print(i)
}

//输出0 1 2 3 4 5 6 7 8 9 10
for i in stride(from: 0, through: 10, by: 1)
{
    print(i);
}

3、相同类型元组可以直接进行比较
默认的比较原则就是便利比较元组的每一个维度,知道找到第一个能够确定比较结果的维度,即是比较结果,有点像按字母排列任务名称的道理
当让我们知道swift支持运算符重载,这样我们就可以根据自己的需要来定义具体的比较算法

let score1 = (chinese:80,english:90)

let score2 = (chinese:70,english:100)

score1 > score2

4、放弃函数的柯理化curry
5、#selector只能生敲#selector比较恶心

myButton.addTarget(self, action: #selector(test), for: UIControlEvents.touchUpInside);

6、函数的参数强制为let常量,不能再使用var标识函数参数,然后在函数体中直接修改参数,这样的操作在swift3是不允许的,也就是说swift3默认的就是值传递不是址传递。如果要使用址传递必须使用inout关键字载变量的类型前面标识

//两个址传递的例子
func swap(_ a: inout Int,_ b: inout Int)
{
    (a,b) = (b,a)
}

var var1 = 4
var var2 = 5

swap(&var1, &var2)

//var1为5
//var2为4

func test(a:inout Int)
{
    a += 10;
}

test(a: &var2);

//var2值为14

7、函数参数必须使用()包裹,以消除歧义,尤其注意当函数被当作参数传递的时候

//在swift2中的Int->Int->Int在swift3中是非法的
(Int)->(Int)->Int
(Int)->Int->(Int)

8、函数变量在定义的时候必须表明函数的参数外部变量名就像OC的selector

func getMaterial(nameTemp name:String,code:String) ->String?
{
    return name + code;
}

func getMaterial(name:String,id:Int) -> String?
{
    return name + "\(id)";
}

let materialForId = getMaterial(name:id:)
let materialForCode = getMaterial(nameTemp:code:)

materialForId("呵呵",10);
materialForCode("呵呵呵","123456");

9、swift3中的系统函数命名规则
动词以-ed或者-ing结尾的表示函数操作不直接作用于对象,而是产生新的对象保存结果;动词没有后缀直接作用于对象本身,修改对象本身

var str = "hello"
str.append(" swift")
//str =  "hello swift"
var str1 = str.appending(" 2017")
//str = "hello swift"
//str1 =  "hello swift  2017"

var score = [50,80,30,20,60,100];
var score_sorted = score.sorted()
//score = [50,80,30,20,60,100]
//score_sorted = [20,30,50,60,80,100]
score.sort()
//score = [20,30,50,60,80,100]

10、枚举名称大写开头,枚举成员小写开头

enum Department:String
{
    case busnissDepartment
    case humanResourcesDepartment
}

11、where关键字使用
12、摒弃C风格eg:GCD,NS开头的系统类库,等等
13、swift中weak不能修饰let,只能修饰var,因为weak变量在指向的对象被释放时,会在自动置为nil,let修饰的是不允许修改的,就此冲突。
14、逃逸闭包@escaping
一旦闭包被放入到新的线程中去执行,就是逃逸闭包,闭包的执行可能会在当前函数return之后
在swift3中去掉了非逃逸闭包关键字@noescaping,默认的闭包都是非逃逸闭包,因为大多数情况下,闭包的执行还是在函数结束return前,所以只有需要的时候才会去添加@escaping表明闭包是逃逸闭包,(常见的是网络请求的回调,无论成功还是失败的回调,都是在网络请求方法return后才会被执行)

上一篇下一篇

猜你喜欢

热点阅读