在WWDC的演示中就可以看出来Swift这个更接近于脚本的语言可以用更少的代码量完成和OC同样的功能。但是对于像我一样在战争中学习战争的同学们来说,天天抱着笨Swift Programming Language Reference之类的大部头看不实际。毕竟还是要养家糊口的。而且,那么1000+页内容讲的东西不是什么都要全部在平时工作中用到的。咱们就把平时用到的全部都放在一起,忘记了立马翻开看看,不知不觉的就学会了之后变成习惯。这样多省事。

变量

 // Variable
var int_variable = 1 // 类型推断
var message : String
var x = 0.0, y = 0.0, z = 0.0

常量

// Constant
let const_int = 1
//const_int = 10 ERROR: can not assign to let value

字符串

// String
// 1. 定义
var empty_string = ""
var another_empty_string = String()
// 2. 拼接
var hello_string = "hello"
var world_string = " world"
hello_string += world_string // hello world let multiplier = 3
//let multiplier_message = "\(mulitplier) times 2.5 is \(Double(multiplier) * 2.5)" // 3. 比较
var hello_world_string = "hello world" hello_string == hello_world_string // all are "hello world", result is true if hello_string == hello_world_string {
println("These two are equal")
}

Tuple

// Tuple
// 1. Unnamed tuple
let http_not_found = (404, "Not Found")
println("tuple item 1 \(http_not_found.0), tuple item 2 \(http_not_found.1)")
// 2. Named tuple
let (statusCode, statusMessage) = (404, "Not Found")
statusCode //
statusMessage // "Not Found" let http_not_found2 = (statusCode:404, statusMessage:"Not Found")
http_not_found2.statusCode //
http_not_found2.statusMessage // "Not Found"
// 3. return tuple
func getHttpStatus() -> (statusCode : Int, statusMessage : String){
// request http
return (404, "Not Found")
}

数组

// Array

// 1. 定义
//var empty_array = [] // 在swift里没事不要这样定义数组。这是NSArray类型的,一般是Array<T>类型的
var empty_array : [Int]
var empty_array2 = [Int]()
var fire_works = [String]()
var colors = ["red", "yellow"]
var fires : [String] = ["small fire", "big fire"]; // Xcode6 beta3里数组的类型是放在方括号里的 var red = colors[0] // 2. append & insert
colors.append("black")
colors += "blue"
colors += fires
colors.insert("no color", atIndex: 0) // 3. update
colors[2] = "light blue"
//colors[5...9] = ["pink", "orange", "gray", "limon"] // 4. remove
colors.removeAtIndex(5)
//colors[0] = nil ERROR! // other
colors.isEmpty
colors.count

字典

// Dictionary
// 1. 定义
var airports : Dictionary<String, String> = ["TYP":"Tokyo", "DUB":"Boublin"]
var airports2 = ["TYP":"Tokyo", "DUB":"Boublin"]
var empty_dic = Dictionary<String, String>()
var empty_dic2 = [:] // 2. update
airports.updateValue("Dublin International", forKey: "DUB")
airports["DUB"] = "Dublin International" // 3. insert
airports["CHN"] = "China International" // 4. check exists
if let airportName = airports["DUB"] {
println("The name of the airport is \(airportName).")
}
else{
println("That airport is not in the airports dictionary.")
} // 5. iterate
for (airportCode, airportName) in airports{
println("\(airportCode):\(airportName)")
} // 6. remove
airports.removeValueForKey("TYP")
airports["DUB"] = nil

枚举

// Enum
// 1. defination & usage
enum PowerStatus: Int{
case On = 1
case Off = 2
} enum PowerStatus2: Int{
case On = 1, Off, Unknown
} var status = PowerStatus.On enum Barcode {
case UPCA(Int, Int, Int)
case QRCode(String)
} var product_barcode = Barcode.UPCA(8, 8679_5449, 9)
product_barcode = .QRCode("ABCDEFGHIJKLMN") switch product_barcode{
case .UPCA(let numberSystem, let identifier, let check):
println("UPC-A with value of \(numberSystem), \(identifier), \(check)")
case .QRCode(let productCode):
println("QR code with value of \(productCode)")
}

方法

// Function
// 1. 定义
func yourFuncName(){ } // 2. 返回值
func yourFuncNameWithReturnType()->String{
return ""
} // 3. 参数
func funcWithParameter(parameter1:String, parameter2:String)->String{
return parameter1 + parameter2
} funcWithParameter("1", "2") // 4. 外部参数名
func funcWithExternalParameter(externalParameter p1:String) -> String{
return p1 + " " + p1
} funcWithExternalParameter(externalParameter: "hello world") func joinString(string s1: String, toString s2: String, withJoiner joiner: String)
-> String {
return s1 + joiner + s2
} joinString(string: "hello", toString: "world", withJoiner: "&") // 外部内部参数同名
func containsCharacter(#string: String, #characterToFind: Character) -> Bool {
for character in string {
if character == characterToFind {
return true
}
}
return false
} containsCharacter(string: "aardvark", characterToFind: "v") // 默认参数值
func joinStringWithDefaultValue(string s1: String, toString s2: String, withJoiner joiner: String = " ")
-> String {
return s1 + joiner + s2
} joinStringWithDefaultValue(string: "hello", toString: "world") //joiner的值默认为“ ” // inout参数
func swapTwoInts(inout a: Int, inout b: Int) {
let temporaryA = a
a = b
b = temporaryA
} var someInt = 3
var anotherInt = 107
swapTwoInts(&someInt, &anotherInt)
println("someInt is now \(someInt), and anotherInt is now \(anotherInt)")
// prints "someInt is now 107, and anotherInt is now 3

// Class
// 1. 定义
class NamedShape {
var numberOfSides: Int = 0
var name: String

// *这样定义的初始化函数,其参数在调用的时候必须作为外名称使用
init(name: String) {
self.name = name
}

// *这样定义的参数,在初始化的时候可以不使用外名称
   init(_ nickName: String){
     self.name = nickName
}
func simpleDescription() -> String {
return "A shape with \(numberOfSides) sides."
}
} // 2. 继承 & 函数重载 & 属性getter setter
class Square: NamedShape {
var sideLength: Double init(sideLength: Double, name: String) {
self.sideLength = sideLength
super.init(name: name)
numberOfSides = 4
} func area() -> Double {
return sideLength * sideLength
} // 函数重载
override func simpleDescription() -> String {
return "A square with sides of length \(sideLength)."
}
} class EquilateralTriangle: NamedShape {
var sideLength: Double = 0.0 init(sideLength: Double, name: String) {
self.sideLength = sideLength
super.init(name: name)
numberOfSides = 3
} // 属性的getter setter
var perimeter: Double {
get {
return 3.0 * sideLength
}
set {
sideLength = newValue / 3.0
}
} override func simpleDescription() -> String {
return "An equilateral triagle with sides of length \(sideLength)."
}
} // 3. 使用
var triangle = EquilateralTriangle(sideLength: 3.1, name: "a triangle")
triangle.perimeter
triangle.perimeter = 9.9
triangle.sideLength

使用闭包给属性赋初值

struct Checkerboard {
let boardColors: Bool[] = {
var temporaryBoard = Bool[]()
var isBlack = false
for i in ... {
for j in ... {
temporaryBoard.append(isBlack)
isBlack = !isBlack
}
isBlack = !isBlack
}
return temporaryBoard
}()
func squareIsBlackAtRow(row: Int, column: Int) -> Bool {
return boardColors[(row * ) + column]
}
}

类(二)

1. 属性的初始化

2. init函数中修改常量属性

struct Color{
// 在初始化函数中可以修改这些在定义时没有给出初始值的属性
let red, green, blue: Double
// stored property(就是下面这样定义的),如果是optional的(结尾时?活着!),可以在初始化函数
// 中不给出初始值,否则必须给出初始值。
var alpha: Double! init(r red: Double, green: Double, blue: Double){
self.red = red
self.green = green
self.blue = blue
} init(white: Double){
red = white
green = white
blue = white
} init(_ aColor: Double){
self.red = aColor
self.green = aColor
self.blue = aColor
}
}

3. 构造函数

// 默认init函数
class ShoppingItem {
var name: String?
// var quantity: Int // 编译错误,要使代码正确需要注释掉这一句
var purchased = false // 除非定义的属性全部都有初始值。optional的属性的默认值是nil。
// 否则的话必须显示定义一个init函数。
init(){ } init(name: String, purchased: Bool){
self.name = name
self.purchased = purchased
} // 结构体等自定义值类型可以直接在一个init函数中使用self.init(...)的方式调用
// 其他的init函数。但是在class(引用类型)中需要显示制定convenience关键字
// 才可以调用其他的init函数
convenience init(name: String){
self.init(name: "hello", purchased: true)
}
} var item = ShoppingItem() struct Color{
// 在初始化函数中可以修改这些在定义时没有给出初始值的属性
let red, green, blue: Double
// stored property(就是下面这样定义的),如果是optional的(结尾时?活着!),可以在初始化函数
// 中不给出初始值,否则必须给出初始值。
var alpha: Double! init(r red: Double, green: Double, blue: Double){
self.red = red
self.green = green
self.blue = blue
} //在init函数中调用其他init函数
init(white: Double){
// red = white
// green = white
// blue = white
self.init(r: 1.0, green: 2.0, blue:1.0)
}
}

convenience的init函数只能在本类中调用。而一般的init函数(也就是designated init)可以在继承的链中在一个类中调用super类的init函数。

继承

不想什么被继承就在什么的前面放个final关键字(以前有@号,现在木有了)。如果在class前面放final关键字的话,那么整个类不可以被继承。

class ShoppingListItem: ShoppingItem{

    final var wishListed: Bool? // 不被继承

    override init(){
super.init(name: "what", purchased: false)
}
}

析构函数

class Vehicle{
var numberOfWheels =
var description: String{
return "\(numberOfWheels) wheel(s)"
} deinit{
// 析构具体内容
}
}

析构函数执行的特点:

1. 系统自动调用,不允许手动调用

2. 执行完本类调执行super类的

3. 执行完析构函数之后实例才释放,所以可以析构函数里可以访问全部属性的值

WEAKUNOWNED关键字

class Customer{
let name: String
var card: CreditCard?
init(name: String) {
self.name = name
}
} class CreditCard{
let number: Int
/*
* weak和owned关键字都用来修饰属性的,为了防止循环引用造成的内存无法释放。
* 区别就在于unowned是一定要有值的。所以unowned只可以用在非可选类型上(non-optional type)
*/
unowned let customer: Customer init(number: Int, customer: Customer){
self.number = number
self.customer = customer
}
}

在闭包中也会出现这样的问题。如果在闭包中使用了self.xxxProperty也会出现对类实例本身的一个强引用,从而出现了循环引用。PS:在闭包中使用类成员的时候必须要用self.的写法。

    }
} class HTMLElement { let name: String
let text: String? lazy var asHTML: () -> String = {
[unowned self] in
if let text = self.text {
return "<\(self.name)>\(text)</\(self.name)>"
} else {
return "<\(self.name) />"
}
} init(name: String, text: String? = nil) {
self.name = name
self.text = text
} deinit {
println("\(name) is being deinitialized")
}
}

其他稍后补充

Swift语法快速索引的更多相关文章

  1. Swift语言快速入门

    Swift语言快速入门(首部同步新版官方API文档和语法的Swift图书,确保代码可编译,作者专家在线答疑,图书勘误实时跟进) 极客学院 编著   ISBN 978-7-121-24328-8 201 ...

  2. Swift语法入门

    正文参考: https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Progra ...

  3. ios -- 教你如何轻松学习Swift语法(一)

    目前随着公司开发模式的变更,swift也显得越发重要,相对来说,swift语言更加简洁,严谨.但对于我来说,感觉swift细节的处理很繁琐,可能是还没适应的缘故吧.基本每写一句代码,都要对变量的数据类 ...

  4. Swift语法之 ---- ?和!区别

    1.常量和变量 Swift语言中是用let来定义常量,并且要初始化.var来定义变量,在let或者var后面申明类型,冒号+空格,然后再加上类型名称. 2.optional(可选)变量 可选变量用于处 ...

  5. Java, C#, Swift语法对比速查表

    原文:Java, C#, Swift语法对比速查表   Java 8 C# 6 Swift 变量 类型 变量名; 类型 变量名; var 变量名 : 类型; 变量(类型推断) N/A var 变量名= ...

  6. 第二章 C#语法快速热身

    C#语法快速热身 语法 if(条件表达式){ 代码块 } 语法 if(条件表达式){ 代码块 }else{ 代码块2 } 语法 if(条件表达式1){ 代码块1 if(条件表达式1)){ }else{ ...

  7. Log4net快速索引参考

    官方项目地址:The Apache log4net project 本文内容仅为相关项参考,不进行具体使用讨论 另转载请注明出处 Log4net快速索引参考 Log4net主要有以下三个部件: log ...

  8. Objective-C基础语法快速入门

    Objective-C基础语法快速入门 2010-11-04 16:32 折酷吧 zheku8 字号:T | T 假如我们对面向对象的思维已经C语言都很熟悉的话,对于我们学习Objective-C将会 ...

  9. ios -- 教你如何轻松学习Swift语法(三) 完结篇

    前言:swift语法基础篇(二)来了,想学习swift的朋友可以拿去参考哦,有兴趣可以相互探讨,共同学习哦.      一.自动引用计数   1.自动引用计数工作机制      1.1 swift和o ...

随机推荐

  1. kafka 高可靠

    1.集群高可靠 ①搭建kafka集群(略) ②重点配置项(每个broker配置相同,只有broker.id不一样) broker.id=1     当前机器在集群中的唯一标识,和zookeeper的m ...

  2. Linux 之rsyslog+LogAnalyzer 日志收集系统

    一.LogAnalyzer介绍 LogAnalyzer工具提供了一个易于使用,功能强大的前端,用于搜索,查看和分析网络活动数据,包括系统日志,事件日志和其他许多日志源.由于它只是将数据展示到我们用户的 ...

  3. Linux的bond模式绑定及模式区别

    [Linux的bond模式配置] 原理: 多块网卡虚拟成一张,实现冗余:多张网卡对外显示一张,具有同一个IP: 工作在网卡是混杂模式的情况下: 对于多物理网卡的 Bond 网卡而言,其中一块物理网卡会 ...

  4. JS中的面向对象

    创建对象的几种常用方式: 1,使用Object或对象字面量创建对象. 2,工厂模式创建对象. 3,构造函数模式创建对象. 4,原型模式创建对象. 使用Object或对象字面量创建对象: var stu ...

  5. MyBatis Generator模板

    注:注意替换红色部分   <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generator ...

  6. Cisco交换机配置VLAN与TRUNK

    0x00前言: 今日在学校里学习了如何搭建vlan和配置等等还有trunk. 由于快下课了.尽快写. 0x01准备: Cisco模拟器 0x02正文: 要求: VLAN 10 左边的IP:192.16 ...

  7. Django 组件-cookie 与 session

    会话跟踪技术 1 什么是会话跟踪技术 我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应.例如你给10086打个电话,你就是客户端,而10 ...

  8. Python网络编程与并发编程

    网络编程基础 黏包 , 并发 计算机网络的发展及基础网络概念 Python 中的进程与 锁 Python IO 多路复用 \协程

  9. Eclipse 异常关闭

    缺失 Java Builder 造成运行main方法,找不到主类, 系统没有自动编译 在.project 文件中添加 <buildSpec> <buildCommand> &l ...

  10. MFC单文档分割区(CSplitterWnd)

    用VS08程序向导,单文档程序,默认设置生成的.工程名为3view; 其中默认生成的视图类CMy3viewView,对应3viewView.h,3viewView.cpp; 在Resourse Vie ...