이번에 넥스터즈 면접 중 기술 면접을 진행하고 나서 내가 아직 많이 부족하다고 느낄 수 있었다.. Race Condition, Dead lock, Priority Inversion 등 멀티 스레드를 운용하면서 일어날 수 있는 문제점 등에 대해서 제대로 개념을 잡아두지 않아 답변에 어려움이 있었다.. 처음엔 조금 속상했지만 그래도 이런 경험을 통해 이러한 키워드, 개념들을 잡고 갈 수 있는 기회가 될 수 있으니까 모르면 배우면 되지~ 하는 마음으로 단계별로 개념을 정리해보도록 하자. 먼저 오늘은 멀티쓰레드 환경에서 Race Condition에 대해서 알아보도록 하자!Race Condition그래서 레이스 컨디션이 뭘까 도대체 경쟁 상태라고 해석할 수 있는 이 상태는 두개 이상의 쓰레드나 프로세스가 공유 자..
챗봇 앱을 구현하면서 TCA를 활용해 아키텍처를 구성할까, 클린아키텍처를 활용해 구성할까 고민하다가 외부라이브러리를 사용하지 않고 클린아키텍처를 통해 제대로 한번 구현해보고 싶은 마음에 클린아키텍처를 활용해 프로젝트를 구성하기로 했다. 이전 블로그 글을 통해 클린아키텍처에 대해서 정리했지만 간단하게 다시 훑고 지나가 보자 클린아키텍처는 크기 Presentation, Domain, Data 로 계층을 나눈다. Presenstation은 UI와 사용자의 상호작용을 처리하는 역할을 담당하고 View와 ViewModel로 나뉜다. View는 사용자의 행동을 받아드려 ViewModel로 전달하게 되고 ViewModel은 사용자 이벤트를 처리하며 UseCase를 호출해 비즈니스 로직을 실행한다. Domain은 핵심..
회사에서 웹뷰를 활용한 챗봇을 만드는 프로젝트가 시작해 Swift에서 웹뷰를 사용하는 방식에 대해서 기록으로 남겨두려고 한다. 요즘 많은 프로젝트에서 웹뷰를 활용한 개발이 많이 이뤄지고 있는데 사실 제대로된 웹뷰를 사용해보지 않아 이번 기회에 공부해보려고 한다.iOS에서 웹뷰를 사용하기 위해서는 주로 WKWebView를 사용한다. 하지만 나는 SwiftUI로 개발을 진행하고 있기 때문에 이 SwiftUI에서는 WKWebView를 사용할 수 없어 UIViewRepresentable를 활용해 UIKit에서 가져와 사용하는 방식으로 구현하려고 한다. UIViewRepresentable 사용UIViewRepresentable은 UIKit의 뷰를 SwiftUI에서 사용할 수 있도록 해주는 프로토콜이다. WKWeb..
11월 25일 월요일 날 세종대학교에서 열린 2024 Let’s Swift에 다녀왔다 첫 컨퍼런스 참여라 많은 기대를 하고 방문하게 되었는데 회사에서 티켓도 사주고 연차도 지원해줘서 아주 나이스.. 덕분에 좋은 경험했다!날씨도 너무 좋고 세종대학교 처음 가봤는데 캠퍼스가 너무 이쁘다.. 대학 졸업한지 한참 지난 다음 대학교에 다시 오니 젊은이들 학교 다니는 모습들에 참 가슴이 몽골몽골해지기도 한 것 같다. 9시 30분부터 입장이 가능했고 나는 9시 30분에 시작으로 착각해 8시 50분에 도착해버렸다.. 조금 더 잘 수 있었는데..처음 도착하면 입장권을 확인하고 앱을 설치하면 스탬프를 받을 수 있었다. 앱을 설치하고 그 안에 시간표랑 여러가지 확인도 할 수 있어서 간편하게 사용하기 위해 미리 다운을 받았다..
Dependency (의존성)우리가 통상 개발하는 앱은 카운터 앱에 자동 카운트 기능을 넣고 싶을수도 있고, 이보다 더 복잡하고 많은 네트워크 코드가 들어가는 상황이 생긴다. 그럴때 Reducer 안에서 이러한 의존성을 가리키는 Dependency가 생기는 경우는 어떻게 처리해야할 지 알아보자. 예를 들어 카운터 앱에 자동 카운트 기능을 넣기 위해 Timer가 필요하게 된다. 이럴 땐 TCA에서 기본적으로 지원하는 Timer의 Dependency를 사용할 수 있다.@Dependency(\.continuousClock) var clock또한, API를 포함해 네트워크 코드들은 통신하는 Client와 의존성이 생기게 된다. 이때 Timer보다 더 복잡한 과정이 필요하지만 이 내용은 추후에 제대로 다시 설명해..
오늘은 SwiftUI에서 Charts 사용에 대해서 글을 남기려고 한다. 먼저 SwiftUI에서 Charts는 Swift 4.0에서 새롭게 나온 API로 데이터를 넣으면 손 쉽게 그 데이터를 시각화 할 수 있도록 차트를 만들어주는 아주 편리한 기능이다. Charts는 iOS 16 버전 이상에만 지원이 되고 해당 차트를 사용하기 위해서는 Xcode 14버전 이상을 사용해야 한다.공식 문서를 통해 더 자세하게 알아보자!https://developer.apple.com/documentation/charts/ Swift Charts | Apple Developer DocumentationConstruct and customize charts on every Apple platform.developer.apple..