본문 바로가기

분류 전체보기98

Swift 메모리 관리(ARC) 메모리의 구조는 코드, 데이터, 힙, 스택으로 구성되어있다. 코드 영역에는 컴파일된 코드가 들어있다. 데이터 영역에는 전역 변수 혹은 타입 변수 중 클래스와 구조체가 들어있다. 공통으로 공유하기 위한 데이터가 저장되는 영역이다. 힙 영역에는 동적 할당되는 크기가 크고, 관리할 필요가 있는 데이터가 저장되는 영역이다. 스택영역에는 함수가 실행되기 위한 임시적인 공간이다. 스코프가 종료되면 자동으로 제거되기에 관리가 필요없는 영역이다. Swift에서 값 형식은 필요 시 항상 메모리의 값이 복사되어 저장되는데 stack 영역에 저장된다. 그리고 값이 들어있는 스코프가 종료되면 메모리에서 자동으로 제거된다. 하지만, 참조 형식은 필요 시 항상 메모리의 주소를 저장하고 값은 heap 영역에 주소는 stack 영역.. 2023. 8. 6.
Swift 고차함수 (map, filter, reduce) 고차함수 함수를 파라미터로 받거나, 함수의 결과 값으로 함수를 리턴하는 함수 (input이나 output이 함수인 함수) 대표적으로 map, filter, reduce가 있음 (forEach, compactMap, flatMap) Sequance, Collection 프로토콜을 따르는 컬렉션에 기본적으로 구현되어 있는 함수 map 기존 배열의 각 값들을 새롭게 매핑해 새로운 배열을 리턴하는 함수 (매핑 방식은 클로저가 제공) let numbers = [1, 2, 3, 4, 5] // numbers.map(transform: (Int) throw -> T) let newNumbers = numbers.map{num in return num + 1 } // 위와 동일하나 간소화된 문법 // let newN.. 2023. 8. 4.
Swift 클로저(Closure) 클로저란? 이름이 없는 함수를 의미함 왜 이름이 불필요할까? 함수를 실행하는 형태가 아닌 전달하는 형태로 사용하기 때문에 이름이 불필요함 ex) 파라미터 전달 등 함수가 필요한 순간 클로저로 정의해서 전달 함수와 클로저 형태의 비교 // 함수의 형태 func myFunction() -> Int { return ... } // 클로저의 형태 {() -> Int in return } 함수를 1급 객체로 취급함, 함수는 타입! 함수를 변수에 할당할 수 있음 함수를 호출할 때, 함수를 파라미터로 전달할 수 있음 함수에서 함수를 반환할 수 있음 중괄호는 함수 // 아래 두 코드는 동일함을 인지할 수 있어야 함 var sample = { print("closure") } var sample = { () -> () .. 2023. 8. 4.
iOS 앱이 만들어지는 원리 (Web과 비교) iOS는 내부적으로 아주 복잡한 메커니즘이 있지만, 실제로 잘 알지 못해도 쉽게 구현 가능하도록 설계되어 있다. 내부적인 매커니즘(앱의 생명주기, 뷰컨트롤러의 생명주기, Drawing Cycle 등)에 의해 완벽하게 통제된다. 웹은 상단부터 아래로, 영역을 나눠 그린다. 화면을 그리는 메커니즘과 내부 동작 매커니즘이 완전 분리된다. 운영체제와 독립적이고, 브라우저의 엔진에 의해 돌아간다 iOS는 오브젝트(대부분 클래스)들을 올려놓고 배치한다. 배치방법에는 프레임 방식과 오토레이아웃 방식 2가지가 있다. 내부 속성/동작들이 이미 내장되어 있다. 하나의 클래스 내에 그리는 매커니즘과 동작에 대한 매커니즘이 공존한다. 그래서 클래스와 객체지향 개념에서 출발할 수 밖에 없다. 앱을 만드는 것은 운영체제와 밀접한.. 2023. 8. 2.
Swift의 self vs Self 이해하기 Swift에서의 self와 Self의 차이 이해하기! self self는 인스턴스를 가리킴 인스턴스 내부에서 인스턴스의 속성을 더 명확하게 가리키기 위해 사용 self.name = name 값 타입에서 인스턴스 자체의 값을 치환할 때 사용 가능 self = Calculator() | 단, 클래스에서는 사용 불가 타입속성/메서드에서 사용하면, 타입 자체를 가리킴 static func sample() { print("\(self.name)") } 타입 인스턴스를 가리킬 때, 타입 자체의 뒤에 붙여서 사용 let a: MyClass.Type = MyClass.self Self Self는 타입을 가리킴 특정 타입 내부에서 타입을 선언하는 위치에 사용 extension Int { static let zero: S.. 2023. 8. 2.
Swift 중첩 타입 (Nested Types) 중첩 타입 타입 내부에 타입을 선언하는 것 사용하는 이유 특정 타입 내에서만 사용 (하위 타입은 상위 타입과 관계가 있어, 상위 타입 없이는 의미가 없는 경우 범위를 명확히 한정지음) 타입 간의 연관성을 명확히 구분하고, 내부 구조를 디테일하게 설계할 수 있음 사용 시에는 중첩타입 전체를 쓰거나 타입이 명확히 정의되어 있는 경우 타입추론이 가능해 줄여서 사용 가능함 class AClass { struct BStruct { enum CEnum { case aCase case bCase struct DStruct { } } var name: CEnum } } let aClass:AClass = AClass() let bStruct:AClass.BStruct = AClass.BStruct(name: .bCas.. 2023. 8. 2.