개발자 / 모바일 / 안드로이드

“떠오르는 자바 대체제” 코틀린 제대로 이해하기

Martin Heller | InfoWorld 2017.11.03

코틀린(Kotlin)은 JVM 및 안드로이드 개발에서 자바에 비해 큰 이점을 제공하며, 같은 프로젝트에서 자바와 매끄럽게 연동된다. 사용하지 않을 이유가 없다.

Image Credit : GettyImagesBank

코틀린은 JVM과 안드로이드를 위한 정적 형식 지정(statically typed) 범용 오픈소스 프로그래밍 언어로, 객체 지향과 함수형 프로그래밍의 특성을 혼합한 언어다. 상호운용성, 안전성, 명확성, 툴 지원에 중점을 두고 있다. 현재 자바스크립트용 코틀린 버전(ECMAScript 5.1)과 네이티브 코드(LLVM 사용)가 준비되고 있다.

코틀린은 인텔리J(IntelliJ) IDEA를 만든 젯브레인스(JetBrains)가 2010년 내놓았으며, 2012년부터 오픈소스화됐다. 현재 코틀린 팀은 20명 이상의 젯브레인스 출신 정규 멤버로 구성되며 깃허브의 코틀린 프로젝트에는 100여 명의 기여자가 있다. 젯브레인스는 대표 제품인 인텔리J IDEA를 포함한 많은 제품에서 코틀린을 사용한다.

코틀린의 첫인상은 군살을 뺀 자바다. 다음 스크린샷은 필자가 자바 코드 샘플(왼쪽)을 코틀린으로 자동으로 변환한 모습이다. 인스턴스화하는 자바 변수에서 보이는, 무의미한 반복이 사라진 것을 알 수 있다.



다음과 같은 자바 이디엄이

StringBuilder sb = new StringBuilder();

코틀린에서는 이렇게 된다.

val sb = StringBuilder()

함수가 fun 키워드로 정의되고, 새 줄에서 세미콜론이 선택 사항임을 볼 수 있다. val 키워드는 읽기 전용 또는 로컬 변수를 선언한다. var 키워드는 가변 속성 또는 로컬 변수를 선언한다.

그럼에도 불구하고 코틀린은 강력한 형식의 언어다. val 및 var 키워드는 형식 추론이 가능할 때만 사용할 수 있다. 그렇지 않은 경우 형식을 선언해야 한다. 형식 추론은 각 코틀린 릴리즈가 나올 때마다 개선되고 있는 것으로 보인다.

화면 양쪽에서 윗부분의 함수 선언을 비교해 보자. 자바의 반환 형식은 프로토타입보다 앞에 오지만 코틀린에서는 프로토타입보다 뒤에 오고, 파스칼처럼 콜론으로 경계를 표시한다.

이 예제에서는 명확하게 드러나지 않지만 코틀린에서는 함수가 클래스 멤버여야 한다는 자바의 요구 사항이 완화됐다. 코틀린에서 함수는 파일의 최상위 수준에서, 다른 함수 안에서 로컬로, 클래스 또는 객체 내부의 멤버 함수로, 그리고 확장 함수로 선언이 가능하다. 확장 함수는 클래스에서 상속하거나 Decorator와 같은 설계 패턴 유형을 사용할 필요 없이 새로운 기능으로 클래스를 확장하는 기능을 제공한다. C#과 비슷한 점이다.

그루비(Groovy) 팬에게 반가운 소식은 코틀린이 빌더를 구현한다는 점이다. 사실 코틀린 빌더는 형식 확인이 가능하다. 코틀린은 위임된 속성을 지원하므로 이를 사용하여 지연(lazy) 속성, 관찰 가능(observable) 속성, 거부 가능(vetoable) 속성, 매핑된 속성을 구현할 수 있다.

다른 언어에서 사용 가능한 많은 비동기 메커니즘은 코틀린 1.1의 실험적 기능인 코틀린 코루틴(coroutine)을 사용해서 라이브러리로 구현할 수 있다. 여기에는 C#과 ECMAScript의 async/await, 고(Go)의 채널, C#과 파이썬의 generators/yield가 포함된다.

코틀린의 함수형 프로그래밍
코틀린에서 최상위 함수를 허용하는 것은 함수형 프로그래밍의 시작에 불과하다. 코틀린은 고차 함수, 익명 함수, 람다, 인라인 함수, 클로저, 꼬리 회귀(tail regression) 및 제너릭도 지원한다. 즉, 코틀린은 함수형 프로그래밍의 모든 기능과 장점을 갖고 있다. 예를 들어 다음 함수형 코틀린 이디엄을 살펴보자.

코틀린에서 목록 필터링하기

val positives = list.filter { x -> x > 0 }

더 짧은 식을 만들려면 람다 함수에 매개 변수가 하나 뿐일 때는 it을 사용한다.

val positives = list.filter { it > 0 }

코틀린에서 쌍 맵/목록 순환하기

for ((k, v) in map) { println(“$k -> $v”) }

kv는 무엇이 되든 상관없다.

Sponsored

회사명 : 한국IDG | 제호: ITWorld | 주소 : 서울시 중구 세종대로 23, 4층 우)04512
| 등록번호 : 서울 아00743 등록발행일자 : 2009년 01월 19일

발행인 : 박형미 | 편집인 : 박재곤 | 청소년보호책임자 : 한정규
| 사업자 등록번호 : 214-87-22467 Tel : 02-558-6950

Copyright © 2024 International Data Group. All rights reserved.