加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

6.3 Swift闭包表达式作为回调函数

发布时间:2020-12-14 06:32:59 所属栏目:百科 来源:网络整理
导读:/** 闭包表达式作为回调函数 */ /** 上节课中呢,说了闭包表达式的语法, 将闭包表达式赋给一个常量并不常用,那种调用方式还不如就写成函数的形式 */ var array = [ 20 , 2 , 3 , 70 , 8 ] showArray (array: array) print ( "--------------" ) bubbleSort

/**

闭包表达式作为回调函数

*/

/**

上节课中呢,说了闭包表达式的语法,

将闭包表达式赋给一个常量并不常用,那种调用方式还不如就写成函数的形式

*/

var array = [20,2,3,70,8]

showArray(array: array)

print("-------------->")

bubbleSort(array: &array)

let intCmp = {

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


// 可以修改闭包表达式

// let x = a % 10

// let y = b % 10

if a > b {

return -1

} else if a < b {

return 1

} else {

return 0

}

}

// 这个就是将闭包作为回调函数了,放到函数形式参数的最后一个,这样方便找

//

bubbleSort2(array: &array,cmp: intCmp)

print("----------------->")

showArray(array: array)

// 好处呢,我们可以修改这个 intCmp

let intCmp2 = {

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

// 可以修改闭包表达式

let x = a % 10

let y = b % 10

if x > y {

return -1

} else if x < y {

return 1

} else {

return 0

}

}

// 可以作为实际参数直接放在这里

bubbleSort2(array: &array,cmp: {

(a: Int,0)"> // 可以修改闭包表达式

let x = a % 10

let y = b % 10

if x > y {

return -1

} else if x < y {

return 1

} else {

return 0

}

})

print("----------------->")

showArray(array: array)



func showArray(array: [Int]) -> Void {

for x in array {

print("(x)")

}

}

// 写个冒泡排序, 用函数

func bubbleSort(array:inout [Int]) -> Void {

let cnt = array.count

for (i,value) in array.enumerated()

{

if i > 0

{

for (j,value2) in array.enumerated()

{

// print("j=====(j)")

// print("====(cnt - i)")

if j < cnt - i

{

if array[j] > array[j+1]

{

let t = array[j]

array[j] = array[j+1]

array[j+1] = t;

}

}

}

}

}

// 不允许用C的方法了

// for var i = 1; i < cnt; i++

// {

//

// for var j = 0; j < cnt-i; j++

// {

//

// if array[j] > array[j+1]

// {

//

// let t = array[j]

// array[j] = array[j + 1]

// array[j + 1] = t

// }

// }

// }

}

// 写个冒泡排序, 用闭包表达式作为回调

func bubbleSort2(array:inout [Int],cmp:(Int,Int) -> Int) {

let cnt = array.count

for (i,0)"> // print("j=====(j)")

// print("====(cnt - i)")

if j < cnt - i

{

if (cmp(array[j],array[j+1]) == -1)

{

let t = array[j]

array[j] = array[j+1]

array[j+1] = t;

}

}

}

}

}

}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读