汇编分析闭包本质

引用类型的赋值操作

class Size {
    var width = 1
    var height = 2
}

值类型、引用类型的let

struct Point {
    var x: Int
    var y: Int
}

let p = Point(x: 1, y: 2)
p = Point(x: 2, y: 3)//❌
p.x = 33//❌
p.y = 44//❌

class Size {
    var w: Int
    var h: Int
    init(w: Int, h: Int) {
        self.w = w
        self.h = h
    }
}

let s = Size(w: 1, h: 2)
s.h = 3
s.w = 4

let str = "Jack"
str.append("_rose")//❌
func testInstanceSize() {
    class Size {
        var w: Int
        var h: Int
        var test: Bool?
        init(w: Int, h: Int) {
            self.w = w
            self.h = h
        }
    }
    
    let s = Size(w: 1, h: 2)//malloc
    print(class_getInstanceSize(Size.self)) // 40
    print(class_getInstanceSize(type(of: s)))// 40
}
testInstanceSize()

嵌套类型

struct TestStruct {
    enum TestEnum {
        case one
    }
    enum TestEnum1 {
           case one
       }
}

枚举、结构体、类都可以定义方法

class Size {

func test() {
}
}


思考: 方法占用实例对象的内存空间吗?
存储在哪里?在内存中,在内存的哪个位置呢?
代码端,函数放在哪里方法就放在哪里,方法本质就是函数


class Size {

func test() {
}
}
func test1() {
}
class Size1 {
}

var s = Size()
s.test()

类似于

var s1 = Size1()
test1(s1)

全局变量

堆空间

栈空间

闭包表达式(Closure Expression)

func sum(_ v1: Int, _ v2: Int) -> { v1 + v2 }

var fn = { (v1 :Int, v2: Int) -> Int  in
  return v1 + v2
}
fn(10, 20)

闭包表达式的简写

func exec(_ v1: Int, _ v2: Int, fn:(Int, Int) -> Int) {
  print(fn(v1, v2))
}
exec(v1: 10, v2: 20, fn: {
(v1: Int, v2:Int) -> Int in
 return v1 + v2
})

省略

exec(v1: 10, v2: 20, fn: {
v1, v2  in
 return v1 + v2
})

再省略

exec(v1: 10, v2: 20, fn: {
v1, v2  in
 v1 + v2
})

再省略

exec(v1: 10, v2: 20, fn: {
 $0 + $1
})

再省略

exec(v1: 10, v2: 20, fn: +)

尾随闭包

如果将一个很长的闭包表达式作为函数的最后一个实参,使用尾随闭包可以增强函数的可读性.

func exec(v1: Int, v2: Int, fn:(Int, Int) -> Int) {
    print(fn(v1,v2))
}
exec(v1: 10, v2: 20) {
  $0 + $1
}

如果闭包表达式作为函数的唯一参数,而且使用尾随闭包的语法,那么就不需要在函数后面添加圆括号.

func exec( fn:(Int, Int) -> Int) {
    print(fn(1,2))
}

调用

exec(fn: {$0+$1})
exec(){$0+$1}
exec{$0+$1}

事栗-数组的排序

func testSort() {
    var arr = [2,3,4,1,6,7,8,3,4]
    arr.sort()
    print(arr)
}
[1, 2, 3, 3, 4, 4, 6, 7, 8]
Program ended with exit code: 0

sort源码

func sort(by areInIncreasingOrder: (Element, Element)->Bool)
///返回true: i1排在i2前面
///返回false: i1排在i2后面
func cmp(i1: Int, i2: Int) -> Bool {
  //大的排在前面
  return i1 > i2
}


你可能感兴趣的:(汇编分析闭包本质)