iOS/Swift

[Swift] 클로저(Closure) (1)

겸둥이xz 2021. 4. 13. 01:17
반응형

 

클로저(Closure)

  • 실행 가능한 코드 블럭입니다.
  • 함수와 다르게 이름 정의는 필요하지 않으며, 매개변수 전달과 반환 값이 존재할 수 있습니다.
  • 함수는 이름이 있는 클로저입니다.
  • 일급 객체(First-class-citizen)로 전달 인자, 변수, 상수 등에 저장 및 전달이 가능합니다.
  • 참조타입입니다.

 

표현방식

  • 중괄호 { }로 감싸져있으며, 괄호를 이용해 파라미터를 정의합니다.
  • -> 를 이용하여 반환 타입을 명시합니다.
  • "in" 키워드를 이용해 실행 코드와 분리합니다.
{ (매개변수 목록) -> 반환타입 in
    실행 코드
}

 

사용예시

// sum이라는 상수에 클로저를 할당
let sum: (Int, Int) -> Int = { (a: Int, b: Int) in
    return a + b
}

let result: Int = sum(1, 2)
print(result) // 3

 

함수의 전달인자로서의 클로저

  • 클로저는 주로 함수의 전달인자로 많이 사용됩니다.
  • 함수 내부에서 원하는 코드블럭을 실행할 수 있습니다.
  • Inline Closure라고 부릅니다.
let add: (Int, Int) -> Int = { (a: Int, b: Int) in
    return a + b
}
 
 
let sub: (Int, Int) -> Int = { (a: Int, b: Int) in
    return a - b
}
 
 
func calculate(a: Int, b: Int, method: (Int, Int) -> Int) -> Int {
    return method(a, b)
}


var result: Int

result = calculate(a: 50, b: 10, method: add)
print(result) // 60


result = calculate(a: 50, b: 10, method: sub)
print(result) // 40


// 함수를 호출할 때 클로저를 작성하여 전달가능
result = calculate(a: 50, b: 10, method: { (left: Int, right: Int) -> Int in
    return left * right
})

print(result) // 500

 

다양한 클로저 표현

클로저는 다양한 모습으로 표현될 수 있습니다.

1. 후행 클로저

result = calculate(a: 10, b: 10) { (left: Int, right: Int) -> Int in
    return left + right
}

print(result) // 20

클로저가 함수의 마지막 전달 인자일 때, 마지막 매개변수 이름을 생략 후 함수 소괄호 외부에 클로저를 구현할 수 있습니다.

 

2. 반환타입 생략

// 후행클로저와 함께 사용가능
result = calculate(a: 10, b: 10) { (left: Int, right: Int) in
    return left + right
}

print(result) // 20

calculate 함수의 method 매개변수는 Int 타입을 반환할 것이라는 사실을 컴파일러도 알기 때문에 클로저에서 반환타입을 명시하지 않아도 됩니다. (in 키워드는 생략할 수 없습니다.)

 

3. 단축 인자이름

// 후행 클로저와 함께 사용할 수 있습니다
result = calculate(a: 10, b: 10) {
    return $0 + $1
}

print(result) // 20

클로저의 매개변수 이름이 불필요하다면 단축 인자이름을 활용할 수 있습니다. 매개변수의 순서대로 $0, $1, ... 처럼 표현합니다.

 

4. 암시적 반환 표현

// 한 줄로 표현가능
result = calculate(a: 10, b: 10) { $0 + $1 }

print(result) // 20

클로저가 반환값이 있다면 클로저 마지막 줄의 결과값은 암시적으로 반환값으로 취급합니다.

 

 

<참고자료>

www.boostcourse.org/mo122/lecture/11297/?isDesc=false

반응형