Skip to content

Latest commit

 

History

History
112 lines (79 loc) · 5.44 KB

README.md

File metadata and controls

112 lines (79 loc) · 5.44 KB

Swift进行中

##MARK / TODO / FIXME 的使用 在 Objective-C 里,预处理指令 #pragma mark 用来把功能区分成有意义的,易于导航的章节。在 Swift 里,没有预处理指令(最接近的是相似的-井号编译配置),但同样可以用注释达到效果 // MARK:。

在 Xcode 6β4 中,以下注释将出现在 Xcode 的代码导航(source navigator)中:

// MARK: (等同于 #pragma,记号后紧跟一个横杠 (-) 会被编译成水平分割线)

// TODO:

// FIXME:

其他常规注释标记,如 NOTE 和 XXX 在 Xcode 中不能被识别。 ##weak和unowned的作用和区别 如果您是一直写 Objective-C 过来的,那么从表面的行为上来说 unowned 更像以前的 unsafe_unretained,而 weak 就是以前的 weak。用通俗的话说,就是 unowned 设置以后即使它原来引用的内容已经被释放了,它仍然会保持对被已经释放了的对象的一个 "无效的" 引用,它不能是 Optional 值,也不会被指向 nil。如果你尝试调用这个引用的方法或者访问成员属性的话,程序就会崩溃。而 weak 则友好一些,在引用的内容被释放后,标记为 weak 的成员将会自动地变成 nil (因此被标记为 @weak 的变量一定需要是 Optional 值)。关于两者使用的选择,Apple 给我们的建议是如果能够确定在访问时不会已被释放的话,尽量使用 unowned,如果存在被释放的可能,那就选择用 weak。

来自这里 ##闭包Closure 示例:

{  
   (a:Int,b:Int)->Int in  

   return a+b  
}  

闭包与函数的主要区别是少了func函数名;所以,函数与闭包的主要区别就是闭包是匿名的.

闭包的使用:闭包赋值给一个变量之后,该变量可以直接当函数使

var plus =  
{  
    (a:Int,b:Int)->Int in  

    return a+b  
}  

##泛型 在尖括号里写一个名字来创建一个泛型函数或者类型。

func repeatItem<Item>(item: Item, numberOfTimes: Int) -> [Item] {
var result = [Item]()
for _ in 0..<numberOfTimes {
    result.append(item)
}
return result
}
repeatItem("knock", numberOfTimes:4)

你也可以创建泛型函数、方法、类、枚举和结构体。

// Reimplement the Swift standard library's optional type
enum OptionalValue<T> {
 case None
 case Some(T)
}
var possibleInteger: OptionalValue<Int> = .None
possibleInteger = .Some(100)

在类型名后面使用where来指定对类型的需求,比如,限定类型实现某一个协议,限定两个类型是相同的,或者限定某个类必须有一个特定的父类

func anyCommonElements <T, U where T: SequenceType, U: SequenceType, T.Generator.Element: Equatable, T.Generator.Element ==    U.Generator.Element> (lhs: T, _ rhs: U) -> Bool {
for lhsItem in lhs {
    for rhsItem in rhs {
        if lhsItem == rhsItem {
            return true
        }
    }
}
return false
}
anyCommonElements([1, 2, 3], [3])

##元组 OC里没有的概念,元组(tuples)把多个值组合成一个复合值。元组内的值可以是任意类型,并不要求是相同类型。 如果你只需要一部分元组值,分解的时候可以把要忽略的部分用下划线(_)标记:

let (justTheStatusCode, _) = http404Error
print("The status code is \(justTheStatusCode)")
// 输出 "The status code is 404"

##可选绑定

使用可选绑定(optional binding)来判断可选类型是否包含值,如果包含就把值赋给一个临时常量或者变量。可选绑定可以用在if和while语句中来对可选类型的值进行判断并把值赋给一个常量或者变量。if和while语句,请参考控制流。

if let actualNumber = Int(possibleNumber) {
  print("\'\(possibleNumber)\' has an integer value of \(actualNumber)")
} else {
  print("\'\(possibleNumber)\' could not be converted to an integer")
}
// 输出 "'123' has an integer value of 123"

这段代码可以被理解为:

“如果Int(possibleNumber)返回的可选Int包含一个值,创建一个叫做actualNumber的新常量并将可选包含的值赋给它。”

多个可选绑定可以用逗号分隔,作为一列表达式出现在一个if语句中。

if let constantName = someOptional, anotherConstantName = someOtherOptional {
  statements
}

##隐式解析可选类型 如上所述,可选类型暗示了常量或者变量可以“没有值”。可选可以通过if语句来判断是否有值,如果有值的话可以通过可选绑定来解析值。

有时候在程序架构中,第一次被赋值之后,可以确定一个可选类型_总会_有值。在这种情况下,每次都要判断和解析可选值是非常低效的,因为可以确定它总会有值。

这种类型的可选状态被定义为隐式解析可选类型(implicitly unwrapped optionals)。把想要用作可选的类型的后面的问号(String?)改成感叹号(String!)来声明一个隐式解析可选类型。

当可选类型被第一次赋值之后就可以确定之后一直有值的时候,隐式解析可选类型非常有用。隐式解析可选类型主要被用在 Swift 中类的构造过程中,请参考无主引用以及隐式解析可选属性