일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 글또
- Rxjava
- theming
- 안드로이드강좌
- 커스텀상태
- 병렬프로그래밍
- viewmodel
- Kotlin
- 스레드
- ReactiveProgramming
- 알게되는
- 책
- kotlin강좌
- 회고
- g 단위테스트
- k8s
- 자바
- 병럴프로그래밍
- Coroutine
- mockito
- 안드로이드
- Compose
- 안드로이드스튜디오
- 코틀린
- Gradle
- 디자인패턴
- android
- 코루틴
- 알고리즘
- 테스트
- Today
- Total
목록스레드 (11)
선생님, 개발을 잘하고 싶어요.
성능에 대해 성능을 높인다? 👉 더 적은 자원으로 더 많은 일을 하도록 한다. 자원 👉 CPU, 메모리, 네트웍 속도, 디스크 속도, DB 속도, 디스크 용량 … 멀티 스레드에 내제된 성능상 비용 스레드 간 작업 조율 시 오버헤드 (락 걸기, 신호 보내기, 메모리 동기화) 컨텍스트 스위칭 스레드 생성 및 제거 여러 스레드를 효율적 스케줄링 더 나은 성능을 위해 병렬 프로그래밍 한다면 프로그램이 확보할 수 있는 자원 최대한 활용 가능한가 체크 남는 자원이 생길 때, 그 자원 역시 최대한 활용 가능한가 체크 🌟 부족한 리소스는 무엇인가? 성능 대 확장성 얼마나 빠르냐, 얼마나 많은 양의 일을 하냐 두 가지 관점에서 생각하기 얼마나 빠르냐 👉 서비스 시간, 대기 시간 얼마나 많은 👉 용량, 처리량 🌟 확장성 ..
안전성(safety)과 활동성(liveness)의 상관 관계 활동성에 문제가 되는 상황을 알아보자. 문제가 되는 사항을 미연에 방지하는 방법을 알아보자. 데드락 식사하는 철학자 문제 원형 테이블에 둘러 앉은 철학자 자기 왼쪽에 있는 젓가락을 집은 다음, 오른쪽 젓가락을 사용할 수 있을 때까지 기다린 후, 오른쪽 젓가락을 집어서 식사를 한다고 하자. 모든 철학자가 자기가 확보한 왼쪽 젓가락을 놓지 않고 오른쪽 젓가락을 기다리다가 식사를 하지 못하게됨 JVM은 데이터베이스 서버와 같이 데드락 상태를 추적하는 기능 ❌ 데드락은 시스템에 부하가 걸리는 최악의 상황에서 모습을 드러낸다. 락 순서에 의한 데드락 두 개의 스레드가 서로 다른 순서로 동일한 락을 확보하려 할 때 발생 같은 순서로 락을 확보하도록 돼 있..
모든 GUI 툴킷은 GUI 관련 작업이 모두 단일 스레드에서 일어나는 단일 스레드 서브시스템으로 구현돼 있다. 단일 스레드 서브시스템 👉 말 그대로, 하나의 스레드 위에서 동작하는 시스템 현실적으로 프로그램이 하나의 스레드만 사용하며 동작하는 건 말이 안되고, 작업 중 일부는 이벤트 스레드, 일부는 일반 애플리케이션 스레드에서 실행된다. 🤔 GUI를 그리는 안드로이드도 이러한 제약이 있다. 안드로이드에서 메인 스레드는 GUI에 접근하고 수정할 수 있는 유일한 스레드를 말하지만, 이 책에서 말하는 그런 역할을 하는 스레드는 이벤트 스레드다. GUI는 왜 단일 스레드로 동작하는가? 터치 이벤트 등 OS → App 방향 수정, 컴포넌트 배경색 설정 등 App → OS 방향 수정으로 하나의 GUI 컴포넌트를 두..
스레드 풀을 설정할 때 사용할 옵션 살피기 Executor를 사용하는 예시 보기 🤔 이미 RxJava, Kotlin coroutine과 같은 작업 관리를 위한 라이브러리를 사용하고 있는데 Executor 디테일을 알아둘 필요가 있을까? 작업과 실행 정책 간의 보이지 않는 연결 관계 일정한 조건을 갖춘 실행 정책이 필요한 작업 작업이 실행 정책에 의존성을 가진 경우가 있다. 의존성 있는 작업 이 경우 스레드 부족 데드락(thread starvation deadlock)이 발생할 수 있다. 이런 작업을 수행하는 경우에 실행 정책을 섬세하게 선택해야 한다. 스레드 한정 기법을 사용하는 작업 같은 스레드를 사용한다고 가정한 작업은, Executor가 단일 스레드로 동작하지 않을 때 스레드 안전성을 쉽게 잃는다...