
[iOS] 동시성 프로그래밍(10) - Structured Concurrency
2023. 2. 16. 17:35
iOS/iOS
Structured Concurrency(구조화된 동시성)란 Structured Programming에 기반을 둔 개념이다. Structured Programming은 procedual하게 읽을 수 있고, 해당 코드의 output을 예측할 수 있는 프로그래밍을 의미한다. 앞선 포스팅에서 살펴본, async & await는 비동기 작업에 대해 Structured Programming이 가능하도록 지원해 주었다. 하지만 저번 포스팅에서 알아본 async & await로 구현한 코드는 단순 비동기이지, parallel한 실행은 할 수 없었다. func fetchOneThumbnail(withID id: String) async throws -> UIImage { let imageReq = imageReques..

[iOS] 동시성 프로그래밍(9) - async, await
2023. 2. 12. 23:26
iOS/iOS
async와 await는 Swift5.5에서 추가된 Concurrency Model로 더 safe, easy, fast 하게 다루기 위해 나온 기능이다. call-back기반의 비동기 함수의 문제점 기존의 비동기 작업이 끝나는 시점을 completion handler를 통해 알 수 있었는데, 이는 procedual(절차적인) 코드가 아니게 되기에 읽기 어려운 부분이 있다. 썸네일을 가져오는 fetchThumbnail 함수가 있다고 정의해 보자. fetchThumbnail 함수 내부에서 위와 같은 작업들이 진행된다. 이 중, dataTask와 preapreThumbnail은 오래 걸리는 작업이기에 비동기 작업으로 진행되어야 한다. 또한, dataTask의 return 값이 이후의 과정에서 쓰이기 때문에, ..

[iOS] Layout(2) - Auto Layout
2023. 2. 2. 02:57
iOS/iOS
view를 화면에 배치하기 위해서는 다음과 같은 정보가 필요하다. size (width, height) location (x, y) Frame-based Layout은 frame을 통해 이러한 정보(size, location)들을 value로 직접 지정한다. 이는 원하는 위치에 설정하면 되기에 유연하며 성능이 빠르다는 장점이 있었지만, Externel changes(외부 변화) 혹은 Internal changes(내부 변화)가 발생하면 개발자가 직접 관리해주어야 한다. External changes란 superview의 size나 shape이 변경될 때 발생한다. 디바이스 회전, 다른 크기의 스크린 지원과 같은 예시가 있다. Internal changes란 UI변경으로 인해 view의 size가 변경될 ..

[iOS] Layout(1) - Frame-Based Layout
2023. 1. 21. 23:02
iOS/iOS
"Frame-Based Layout"은 Programmatically하게 view들의 frame을 지정해주는 방식이다. Frame "Frame Rectangle"은 superView로부터 view의 location과 size를 정의한다. var frame: CGRect { get set } frame은 CGRect 타입의 변수인데, CGRect은 location을 저장할 수 있는 origin프로퍼티와 size를 정의할 수 있는 size 프로퍼티가 존재한다. public struct CGRect { public init() public init(origin: CGPoint, size: CGSize) public var origin: CGPoint public var size: CGSize } 이때 정의한 ..
[Swift] Properties(2) - Wrappers, Type
2023. 1. 18. 23:40
iOS/Swift
Property Wrapper Property Wrapper는 프로퍼티가 저장되는 방식을 관리하는 코드와 프로퍼티가 정의되는 코드 사이에 분리된 계층을 추가해 준다. 즉, 도형의 각 변의 최대 길이를 정하고 싶다고 가정해 보자. 그렇다면 코드는 아래와 같이 구현해야 한다. class Rectangular { private var _width: Int = 10 private var _height: Int = 15 private var maxLegth: Int = 30 var width: Int { get { return _width } set { _width = min(maxLegth, _width) } // 저장하는 방식을 관리하는 코드 } var height: Int { get { return _hei..
[Swift] Properties(1) - Stored, Computed, Observer
2023. 1. 17. 21:03
iOS/Swift
Swift에서 Property는 크게 5가지로 나뉜다. Stored Properties(저장 프로퍼티) Computed Properties(연산 프로퍼티) Property Observers(프로퍼티 감시자) Property Wrappers(프로퍼티 래퍼) Type Properties(타입 프로퍼티) Stored Properties 가장 간단한 형태의 Stored Properties는 class 혹은 structure의 instance에만 관련된 값을 저장한다. variable Stored Property(변수 저장 프로퍼티)는 var 키워드를 사용하며, constant Stored Property(상수 저장 프로퍼티)는 let 키워드를 사용한다. struct SomeStruct { var variable..

[iOS] 동시성 프로그래밍(8) - OperationQueue
2023. 1. 17. 16:58
iOS/iOS
OperationQueue는 내부적으로 DispatchQueue를 기반으로 하여, 더 많은 부가적인 기능을 사용할 수 있는 Queue이다. 부가적인 기능으로는 "작업 취소 및 일시 정지", "작업 순서 지정", "CompletionBlock"등이 있다. GCD의 Dispatch Queue는 Task를 다음과 같이 클로져 형태로 추가하였다. DispatchQueue.global().async { ...}반면, OperationQueue의 작업의 단위는Operation이라는 추상 클래스를 구체화한 Object의 instance가 된다. Operation은 수행할 작업들을 캡슐화를 한다는 점에서 재사용에 대한 이점이 있다. Operation 앞서 말했듯이 Operation은 추상(abstrat) 클래..

[iOS] 동시성 프로그래밍(7) - Thread-Safe
2023. 1. 14. 22:47
iOS/iOS
지난 포스팅을 통해 Race Condition, DeadLock, Priority Inversion과 같은 Concurrency Problem들에 대해 알아보았다. Race Condition은 Thread-Safe하게 코드를 작성함으로써 해결할 수 있다고 언급하였는데, 우선 Thread-Safe가 무엇인지에 대해 알아보자. Thread-Safe란 멀티 쓰레딩 환경에서 어떤 함수, 변수 혹은 객체가 여러 Thread로부터 동시에 접근하여도 프로그램의 실행에 문제가 없음을 의미한다. 엄밀히 말하자면, 동시에 여러 Thread에서 접근하여도 결과에 이상이 없음을 의미한다. 이러한 Thread-Safe를 지키기 위해 여러 가지 방법이 존재하는데, 이 중 Mutual Exclusion(상호 배제)을 알아보자. M..

[iOS] 동시성 프로그래밍(6) - Concurrency Problems
2023. 1. 10. 22:29
iOS/iOS
concurrency problem(동시성 문제)란멀티 쓰레딩 환경에서 공유자원에 동시에 접근하여 발생하는 문제를 말한다. 동시성 문제에는 크게 3가지가 있다. Race Condition (경쟁 상태)DeadLock (교착 상태)Priority Inversion (우선순위 뒤바뀜) Race Condition Race Condition(경쟁상태)이란,공유자원에 여러 쓰레드가 동시에 접근하게 되어, 작업의 접근 순서에 따라 결과가 바뀌는 문제를 의미한다. 더 정확히 얘기하자면, 공유자원에 대한 쓰기 작업에 의해 발생한다. (읽기 작업은 상관없음)for i in 1...5 { print("--- \(i)번째 ---") let group = DispatchGroup() var s..

[RxSwift] Operator(3) - Combining
2023. 1. 8. 19:12
iOS/RxSwift
이번 포스팅에서는 sequence들을 모으고, 여러 sequence내의 데이터들을 병합하는 방법에 대해 알아보자. startWith(_:) subscriber가 Observable을 구독하고, 요소를 방출받을 때 초기값을 지정해 주는 연산자이다. Observable의 타입과 초기값의 타입이 같아야 한다. let observable = Observable.of("A", "B", "C") observable .startWith("alphabet will start to emit") .subscribe( onNext: { print($0) } ) .disposed(by: disposBag) /* prints: alphabet will start to emit A B C */ concat(_:) concat은 ..
[iOS] 동시성 프로그래밍(5) - DispatchSemaphore
2023. 1. 4. 21:35
iOS/iOS
Semaphore동시성 프로그래밍에서는 여러 작업들이 공유 자원을 사용하기 때문에, 여러가지 문제가 발생한다. 이러한 문제들은 둘 이상의 작업들이 공유자원에 접근하면 문제가 생기는 코드 영역인 Critical Section에서 발생하는데, 공유자원에 접근하여 발생하는 문제 중 하나로 두 작업의 접근 순서에 따라 결과가 바뀌는 문제가 있다.for _ in 1...5 { let group = DispatchGroup() var someNumber = 10 DispatchQueue.global().async(group: group) { someNumber *= 10 } DispatchQueue.global().async(group: group) { ..
[iOS] 동시성 프로그래밍(4) - DispatchWorkItem
2023. 1. 4. 17:28
iOS/iOS
기존의 DispatchQueue에서의 작업은 다음과 같이 클로저 형태로 작성하였다. DispatchQueue.global().sync { task(1) task(2) } DispatchQueue.global().async { task(1) task(2) } 하지만, 같은 작업이 반복되는 경우 똑같은 코드를 작성해야 하는데, DipsatchWorkItem을 사용하면 작업들을 캡슐화하여 재사용성을 늘릴 수 있다. DispatchWorkItem DispatchWorkItem은 작업들을 캡슐화 할 수 있는데, 사용은 다음과 같다. let workItem = DispatchWorkItem { task(1) task(2) } DispatchQueue.global().async(execute: workItem) Di..