일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 파이썬
- JVM
- 백준 16235
- 백준 파이썬
- Coroutine
- 백준 15685
- 백준 17779
- JPA
- 백준
- re.split
- 백준 17626
- 백준 16719
- with recursive
- 프로래머스
- spring security
- MSA
- springboot
- java 기술면접
- MySQL
- spring oauth
- sql 기술면접
- Kotlin
- 웹어플리케이션 서버
- 백준 16236
- 프로그래머스
- java
- Spring Boot
- 백준 19238
- Spring
- spring cloud
- Today
- Total
목록Programming/Kotlin (5)
시작이 반
Tool : Jmeter 환경 : CPU 4Core 8Thread 1000명의 유저가 30초가 걸리는 api를 동시 호출 TEST1 구성 : netty + coroutine ( context : Dispatchers.IO ) @PostMapping("/api/test") suspend fun testApi():MutableMap = withContext(Dispatchers.IO){ log.info(">>>>>>>>>>>> start suspend") performService.measureTestPerform() } suspend fun measureTestPerform(): MutableMap = withContext(Dispatchers.IO) { val map = mutableMapOf() val..
Kotlin은 비동기 작업을 다룰 수 있는 동시성 라이브러리 이다. 동시성에는 잘못된 사용으로 여러 문제를 발생시킬 수 있는데 공유 데이터가 그중 하나이다. 여러 코루틴이 동시에 공유된 변수나 자료구조에 접근 하는 경우 데이터 경합이 발생할 수 있으며 이럴 때 해결할 수 있는 방법에 대해서 알아보자. 문제 코드 import kotlinx.coroutines.* import kotlin.random.Random import kotlin.system.measureTimeMillis suspend fun massiveRun(action: suspend () -> Unit){ val n = 100 val k = 1000 val elapsed = measureTimeMillis { coroutineScope { ..
여러개의 코드를 동시에 실행시키기 위해서는 Coroutine을 알기 전에는 쓰레드라는 개념밖에 생각나지 않았다. 쓰레드는 다수의 작업을 동시에 처리할 수 있으며, 일반적으로 쓰레드는 선점형으로 멀티태스킹이 가능하다. 하나의 작업이 한 쓰레드에서 발생하고 여러개의 작업을 동시 실행시키기위해 멀티 쓰레드를 사용한다. 멀티쓰레드 환경에서 CPU가 여러 Task를 바꿔 실행하기 위해 Context Switching을 하게 되고 이때 현재 PCB, 다음 PCB등에 대한 정보를 적재시키기는 등 Overhead가 매우 커질 수 있다. Coroutine 또한 여러 작업을 병렬적으로 처리하는 방법으로 비선점형으로 멀티태스킹이 가능하다. suspend와 resume을 사용하여 서브루틴을 구성하고 하나의 쓰레드에서 여러개의..
CoroutineScope CoroutineSocpe는 Coroutine이 실행될 수 있는 범위를 나타낸다. 이 범위는 Coroutine의 라이프사이클과 관련이 있으며 Coroutine이 완료되거나 종료될때 해당 범위가 생성되거나 없어진다. 코루틴 스코프 내에서 실행되는 코루틴은 부모-자식 관계를 가지며 자식의 코루틴이 예외가 발생하면 부모로 전파를 하여 모두 종료가된다. (But, 슈퍼 바이저 잡을 사용하면 예외 전파를 자식에게만 할 수 있다.) 코루틴 스코프를 만드는 방법에는 하위와 같은 방법 등이 있다. 코루틴 스코프 빌더 코루틴 빌더 runBlocking launch coroutineScope async withContext produce supervisorScope actor GlobalScop..
변수 선언 val : 불변 var : 가변 if로 초기화도 가능 var a = if( true ) { 0 } else { 1} for문 기본 for문 for( i in 0..10 ) -> 0 ~ 10까지 for( i in 10 downTo 0 ) -> 10 ~ 0까지 for( i in a..z ) -> a ~ z 까지 for(i in z downTo a) -> z ~ a 까지 for( (index, element) in (a..z).withIndex() ) : 인덱스도 같이 줄수 있음 배열 for문 for( element in array ) : 원소 반환 for( index in array.indices ) : 인덱스 반환 for( (index, element) in array.withIndex() ) ..