[Swift 정면돌파] 08. 클로저

H43RO·2021년 8월 4일
1

Swift 정면돌파

목록 보기
8/19
post-thumbnail

본 시리즈는 아래 강의자료를 기반으로 작성되었습니다.
https://www.boostcourse.org/mo122/joinLectures/38564

오늘은 클로저 개념에 대하여 학습해보았다. 클로저는 함수형 프로그래밍 언어인 스위프트에게 있어 일급객체로 취급되기 때문에, 익숙하지 않더라도 꾸준히 익혀나가야 할 것 같다. 특히 여러가지 축약 표현이 가능한 만큼, 깊이 이해하고 있지 않으면 다른 사람의 코드를 보기 어려울 수도 있을 것 같다.

클로저 - 기본개념

클로저 개념

→ 클로저는 실행이 가능한 코드 블럭
→ 함수와 다르게 이름 정의는 필요없지만, 매개변수 전달과 반환 값이 존재할 수 있다는 점이 동일함
→ 함수는 이름이 있는 클로저임
→ 일급객체로 전달인자, 변수, 상수 등에 저장 및 전달이 가능함

기본 클로저 문법

→ 클로저는 중괄호로 감싸져있고, 괄호를 이용해 파라미터 정의하며 -> 를 이용해 반환 타입 명시
in 키워드를 이용하여 실행 코드와 분리하게 됨

클로저 사용

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

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

함수 전달인자로서 클로저 사용

→ 클로저는 주로 함수 전달인자로 많이 사용이 도고, 함수 내부에서 원하는 코드블럭을 실행할 수 있음

let add: (Int, Int) -> Int
add = { (a: Int, b: Int) in
    return a + b
}

let substract: (Int, Int) -> Int
substract = { (a: Int, b: Int) in
    return a - b
}

let divide: (Int, Int) -> Int
divide = { (a: Int, b: Int) in
    return a / b
}

func calculate(a: Int, b: Int, method: (Int, Int) -> Int) -> Int {
    return method(a, b)
}

var calculated: Int

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

calculated = calculate(a: 50, b: 10, method: substract)
print(calculated)  // 40

calculated = calculate(a: 50, b: 10, method: divide)
print(calculated)  // 5

// 따로 클로저를 상수/변수에 넣어 전달하지 않고 함수를 호출할 때 클로저를 만들어 넘길 수도 있음

calculated = calculate(a: 50, b: 10, method: { (left: Int, right: Int) -> Int in
    return left * right
})

print(calculated)  // 500

클로저 - 고급개념

후행 클로저

→ 클로저가 함수 마지막 전달인자면, 마지막 매개변수 이름을 생략한 후 함소 소괄호 외부에 클로저 구현 가능

// 클로저를 매개변수로 갖는 함수와 결과값을 저장할 변수 result 선언
func calculate(a: Int, b: Int, method: (Int, Int) -> Int) -> Int {
    return method(a, b)
}

var result: Int

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

print(result) // 20

반환 타입 생략

→ method 매개변수 (클로저) 가 Int 타입을 반환한다는 사실을 암시적으로 알고 있음

result = calculate(a: 10, b: 10, method: { (left: Int, right: Int) in
    return left + right
})  // 단, in 키워드는 생략 불가능

print(result) // 20

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

print(result) // 20

단축 인자 이름

→ 클로저 매개변수 이름이 굳이 불필요하다면, 단축 인자 이름 활용 가능
→ 단축 인자 이름은 클로저 매개변수의 순서대로 $0, $1, $2 ... 처럼 표현

result = calculate(a: 10, b: 10, method: {
    return $0 + $1
})

print(result) // 20

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

print(result) // 20

암시적 반환 표현

마지막 줄의 결과값을 반환값으로 취급함 (국룰)

result = calculate(a: 10, b: 10) {
    $0 + $1
}

print(result) // 20

result = calculate(a: 10, b: 10) { $0 + $1 }

print(result) // 20

클로저를 잘 써먹으면...

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

// 축약 후
result = calculate(a: 10, b: 10) { $0 + $1 }

print(result) // 20
profile
어려울수록 기본에 미치고 열광하라

0개의 댓글