一、编译器和语法变化
函数或方法参数
在Swift的历史版本中出现过在调用函数时不需要指定任何函数参数(或者从第二个参数开始指定参数名),在调用方法时则必须从第二个参数开始必须指定参数名等多种情况,而在Swift3.0中不管是函数还是方法都必须从第一个参数开始必须指定参数名(当然可以使用“_”明确指出调用时省略参数)。
func sum(num1:Int,num2:Int)->Int{
return num1 + num2
}
sum(num1: 1,num2: 2)
func increase(a:Int){
var a = a
a += 1
}
func increase( a:inout Int) {
a += 1
}
方法返回值
Swift 3.0 中方法的返回值必须有接收否则会报警告,当然其实主要目的是为了避免开发人员忘记接收返回值的情况,但是有些情况下确实不需要使用返回值可以使用"_"接收来忽略返回值。当然你也可以增加@discardableResult 声明,告诉编译器此方法可以不用接收返回值。
struct Caculator {
func sum(a:Int,b:Int) -> Int {
return a + b
}
@discardableResult
func func1(a:Int,b:Int) ->Int {
return a - b + 1
}
}
let ca = Caculator()
ca.sum(a: 1,b: 2)
let _ = ca.sum(a: 1,b: 2)
ca.func1(a: 1,b: 2)
可选类型
Swift3.0对于可选类型控制更加严谨,隐式可选类型和其他类型的运算之后获得的是可选类型而不是隐式可选类型。
let a:Int! = 1
let b = a + 1
let c = a
Selector的变化
Selector的改变其实从1.0到3.0经历了多次变化,从最早的@Selector("method:") 到现在的#selector(method(param1:)) 可以说经历了多次修改,好在它变得越来越好,毕竟字符串操作对于语法检查来说是很无助的。
class MyClass {
@objc func sum(a:Int,b:Int) -> Int {
return a + b
}
func func1(){
let _ = #selector(sum(a:b:))
}
}
协议中的可选方法
在Swift3.0之前如果要定义协议中可选方法,只需要给协议加上@objc之后方法使用optional修饰就可以了,但是Swift3.0中除了协议需要@objc修饰,可选方法也必须使用@objc来修饰。
@objc protocol MyProtocol {
@objc optional func func1()
func func2()
}
取消++、--操作符
var d = 1
d++
取消C风格for循环
for i in 0 ..< 10 {
debugPrint(i)
}
二、SDK类库变化
大家都知道Swift诞生在Objective-C已经发展的相当成熟的情况下,为了保证ObjC开发人员顺利过渡到Swift,也因为Swift处于初级阶段,很多类库和方法命名都尽量和ObjC保持一致,在使用Swift开发iOS应用中处处可以看到ObjC的影子。但是作为一门Modern语言Swift还是做出了改变,从中可以看出日后Swift将彻底摆脱ObjC的影子。这其中包括重新导入Foundation消除类型前缀、方法名去重、函数和方法去C风格等等。
命名
let url1 = URL(string: "www.cmjstudio.com")
let isFileURL = url1?.isFileURL
let data1 = Data()
var array1 = [1,2,3]
array1.append(contentsOf: [4,5,6])
array1.remove(at: 0)
let color1 = UIColor.red()
let label1 = UILabel()
label1.textAlignment = .center
let btn1 = UIButton()
btn1.setTitle("hello",for: UIControlState())
去C风格
Swift发展初期很多类库的引入依然保持的ObjC风格,但是ObjC由于根出C语言,因此很多操作其实并不是对象和方法操作而是C语言的函数形式。到了Swift3.0之后这一现状将发生变化,全局函数将会变成某些类型的方法;某些常量定义将以某个枚举类型的成员来表示。
let rect1 = CGRect(x: 0,y: 0,width: 100,height: 100)
if let context1 = UIGraphicsGetCurrentContext() {
CGContext.fillPath(context1)
}
let queue = DispatchQueue(label: "myqueue")
queue.async {
debugPrint("hello world!")
}
NotificationCenter.defaultCenter().addObserver(self,selector: #selector(userDefaultChange()),name: UserDefaults.didChangeNotification,object: nil)
集合API的变化
let array1 = [1,3]
let next = array1.index(after: 0)
let first = array1.first { (element) -> Bool in
element > 1
}
let r = Range(0..<3)
for subview in sequence(first: self.view,next: { $0?.superview }){
debugPrint(subview)
}
新的浮点协议
Float、Double、CGFloat使用了新的协议,提供了提供 IEEE-754标准的属性和方法。
let a = 2 * Float.pi
let b = 2.0 * .pi
三、从Swift_2.2迁移到Swift_3.0
可以看出如果要更新到Swift3.0现有项目需要作出大量修改,经过使用之前的项目进行测试,区区十个类文件就出现了一百多个错误,不过好在Xcode 8已经提供了很好用的迁移工具(Xcode:Editor - Convert - To Current Swift Syntax),经过迁移工具转化后仅仅发现两处错误需要手动修正。在使用这个工具的时候大家会看到如下界面:
Swift 2.3?没错Swift2.2和Swift 3.0中间还有个Swift 2.3,Apple也解释了什么是Swift 2.3,其实就是Swift 2.2 + New SDKs。之所以如此是因为Xcode 8目前还是beta版,使用Swift 3.0进行开发的应用还不能提交App Store,因此在Swift 2.2基础上使用新的SDK开发还是有存在必要的。 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|