本篇分为两部分:
一、Swift中的方法嵌套
二、Swift中的命名空间
一、Swift中的方法嵌套
在 swift 中我们可以让方法嵌套方法,如:
func appendQuery(var url: String,
key: String,
value: AnyObject) -> String { func appendQueryDictionary(url: String,
key: String,
value: [String: AnyObject]) -> String {
//...
return "result"
} func appendQueryArray(url: String,
key: String,
value: [AnyObject]) -> String {
//...
return "result"
} func appendQuerySingle(url: String,
key: String,
value: AnyObject) -> String {
//...
return "result"
} if let dictionary = value as? [String: AnyObject] {
return appendQueryDictionary(url, key: key, value: dictionary)
} else if let array = value as? [AnyObject] {
return appendQueryArray(url, key: key, value: array)
} else {
return appendQuerySingle(url, key: key, value: "value")
}
}
二、Swift中的命名空间
我们之前在使用 OC 开发时,它是没有命名空间的,所有的代码和引用的静态库最终都会被编译到同一个域和二进制中,这样的后果是一旦我们有重复的类名的话,就会导致编译时的冲突和失败。为了避免这种事情的发生,OC 的类型一般都会加上两到三个字母的前缀,比如 MJExtense,MJRefresh,MBProgressHUD 这样。但是前缀并不意味着保证能够不冲突,Swift 使用命名空间后为我们解决了该问题
// MyFramework.swift
// 这个文件存在于 MyFramework.framework 中
public class MyClass {
public class func hello() {
print("hello from framework")
}
}
// MyApp.swift
// 这个文件存在于 app 的主 target 中
class MyClass {
class func hello() {
print("hello from app")
}
}
MyClass.hello()
// hello from app
MyFramework.MyClass.hello()
// hello from framework
另一种策略是使用类型嵌套的方法来指定访问的范围
struct MyClassContainer1 {
class MyClass {
class func hello() {
print("hello from MyClassContainer1")
} }
}
struct MyClassContainer2 {
class MyClass {
class func hello() {
print("hello from MyClassContainer2")
} }
} // 使用时:
MyClassContainer1.MyClass.hello()
MyClassContainer2.MyClass.hello()
这样我们就可以避免去使用一些稀奇古怪的前缀了。