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后才会被执行)