Closures闭包

//: Playground - noun: a place where people can play

import UIKit

/*

闭包

Swift ====> Closures

Ruby OC ====> Block

Python C++11 ====> Lamba

Javescript =====> Anonymous Function(匿名函数)

*/

//冒泡排序

func sortInts(inout data : [Int], function : (Int,Int)->Bool) {

for var i = 0; i < data.count - 1; i++ {

for var j = 0; j < data.count-1-i; j++ {

if function(data[j], data[j+1]) {

swap(&data[j], &data[j+1])

}

}

}

}

func rule(a : Int, b : Int) ->Bool {

return a > b

}

func rule1(a : Int, b : Int) ->Bool {

return a < b

}

var a = [1, 3, 9, 0, 8, 2, 5, 7, 6, 4]

sortInts(&a, rule)

a

sortInts(&a, rule1)

a

//闭包函数 实际上就是函数 是匿名函数

//{

//    (parameters)->returnType in

//        //语句

//        retrun xxx

//}

sortInts(&a, {

//    (Int,Int)->Bool

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

return a > b

})

a

func rule2(a : Int, b : Int)->Bool{

return a < b

}

sortInts(&a, {

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

return a < b

})

a

//闭包函数有些事可以省略

//可以把参数类型省略,类型从传入的参数中推断出来

sortInts(&a, {

(a, b)->Bool in

return a < b

})

//可以把返回值省略,采用了追踪返回值类型

sortInts(&a, {

(a, b) in

return a < b

})

//如果只有一条语句, 可以省略return

sortInts(&a, {

(a, b) in a < b

})

//参数名可以不用写,使用默认的$0, $1, $2...来代替

sortInts(&a, { $0 < $1 })

//甚至可以直接省略参数,而直接使用运算符来表示函数的内容

sortInts(&a, >)

a

var i : Int = 10

func setNum(inout a : Int,function : (inout Int) ->()) {

function(&a)

}

setNum(&i, {

//(+5 , -10, 100)

(inout a : Int) in a+=20

})

func add_5(inout n : Int) {

n += 5

}

func add_10(inout n : Int) {

n += 10

}

func addArr(inout array : [Int], function : (inout Int)->() ) {

for var i = 0; i < array.count; i++ {

function(&array[i])

}

}

var array = [1, 2, 3, 4, 5]

addArr(&array, add_5)

array

addArr(&array, add_10)

array

//对字符串进行排序,用的是系统自带的排序函数

var names = ["aaa","cdc","add","bbb"]

sort(&names)

names

//Swift 的排序函数 > 从大到小

sort(&names, { (a, b) -> Bool in

a > b

})

sort(&names, <)

//sorted

//map()

let digitNames = [0:"零",1:"一",2:"二",3:"三",4:"四",5:"五",6:"六",7:"七",8:"八",9:"九"]

let numbers = [16, 58, 510]

//map是数组的方法,可以迭代数组中每一个元素传入闭包函数中执行一次,并执行结果生成一个新的数组返回出来

let strings = numbers.map( {

(var number) ->String in

var output = ""

while number > 0{

output = digitNames[number % 10]! + output

number /= 10

}

return output

}

)

let _is = numbers.map( {

(var number) ->Int in

var a = number + 50

return a

}

)

strings

var aa = 10

numbers

_is

时间: 2024-09-29 02:48:13

Closures闭包的相关文章

Swift 中的Closures(闭包)详解

Swift 中的Closures(闭包)详解 在Swift没有发布之前,所有人使用OC语言编写Cocoa上的程序,而其中经常被人们讨论的其中之一 -- Block 一直备受大家的喜爱.在Swift中,同样有这样的一个角色,用于当开发者需要异步执行的之后使用的一种语法 - Closure.中文翻译为闭包. 闭包出了可以进行异步执行之外,它的完整使用还依赖闭包本身的变量.常量的捕获.闭包捕获并存储对它们定义的上下文中的任何常量和变量的引用,这也就意味着,你可以在任何时候异步执行闭包的时候获取之前的所

JS-闭包(Closures)和let声明块级作用域变量

闭包: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Closures 闭包是函数和声明该函数的词法环境的组合. let: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Statements/let let 语句声明一个块级作用域的本地变量,并且可选的将其初始化为一个值. 例:闭包和let修正匿名函数访问的变量 function foo(){ v

python 15 闭包函数

目录 1.函数对象 2.函数嵌套 3.闭包函数 4.闭包的用途 1.函数对象 精髓:把函数当成变量去用,具体可以分为四个方面的使用 1.可以赋值,函数名A赋值给B,直接B()就可以引用该函数了 f=func print(f,func) f() 2.函数可以作为参数传入另外一个函数 def foo(x): # x = func的内存地址 # print(x) x() foo(func) # foo(func的内存地址) 3.函数的返回值可以是一个函数 def foo(x): # x=func的内存

Lua 架构 The Lua Architecture

转载自:http://magicpanda.net/2010/10/lua%E6%9E%B6%E6%9E%84%E6%96%87%E6%A1%A3/ Lua架构文档(翻译) 十 102010 前段时间翻译了lua官方关于lua5架构设计的一份文档,现在分享给大家. 注意:所有版权都归lua官方所有,本人仅将其翻译为中文,以方便中文阅读者.翻译中出现任何错误导致的结果,本人不负任何责任. 如果有任何翻译错误,以及意见与建议,请email本人.邮件地址:[email protected]. 转载请注

Swift学习——A Swift Tour 函数

Functions and Closures  函数和封闭性(闭包) Functions  函数的使用 Swift中的函数定义和OC中有明显的差别了,使用func定义函数,在括号里定义參数和类型,用 -> 定义返回值类型 func greet(name: String, day: String) -> String { return "Hello \(name), today is \(day)." } greet("Bob", "Tuesda

Objective-C文章中的生词

Objective-C http://rypress.com/tutorials/objective-c/index C Basics    http://rypress.com/tutorials/objective-c/c-basics Comments 注解   Inline comments   Block comments   Confusing snippest困惑的(代码)片段   self-documenting 自我记录   Variables 变量   Statically

cala 函数式编程

变换算子Transform scala> List(1,2,3,4,5).map(_*2) res0: List[Int] = List(2, 4, 6, 8, 10) scala> List(1,2,3,4,5)reduceLeft{*} res3: Int = 120 函数Closures (闭包) scala> var factor = 3 factor: Int = 3 scala> val multipilier = (i:Int) => i* factor mul

Google JavaScript规范

前言 此文档为翻译google的标准javascript规范 请与以下原文对照阅读 有异议的地方以原文为准 原文地址google javascript规范 http://google-styleguide.googlecode.com/svn/trunk/javascriptguide.xml 文中推荐使用的工具是google推荐使用的,请根据实际情况选用 文中定义的很多格式主要是为了考虑js文件编译(js最小化)的问题,如果在项目中考虑使用 js文件编译 请尽量遵守 此文档不仅仅是一份编码风格

面向对象的JavaScript-009-闭包

引自:https://developer.mozilla.org/cn/docs/Web/JavaScript/Closures 闭包是指能够访问自由变量的函数 (变量在本地使用,但在闭包中定义).换句话说,定义在闭包中的函数可以“记忆”它被创建时候的环境. 词法作用域 考虑如下的函数: function init() { var name = "Mozilla"; function displayName() { alert(name); } displayName(); } ini