Steady Seller

Kotlin in Action [코틀린 컴파일러 개발자가 직접 알려주는 코틀린 언어 핵심(Kotlin 1.7 대응 / 자바스크립트 개발 관련 부록 추가)]

  • 원서명Kotlin in Action (ISBN 9781617293290)
  • 지은이드미트리 제메로프(Dmitry Jemerov), 스베트라나 이사코바(Svetlana Isakova)
  • 옮긴이오현석
  • ISBN : 9791161750712
  • 36,000원
  • 2017년 10월 31일 펴냄
  • 페이퍼백 | 678쪽 | 188*235mm
  • 시리즈 : 모바일 프로그래밍

책 소개

소스 코드 파일은 여기에서 내려 받으실 수 있습니다.

요약

코틀린이 안드로이드 공식 언어가 되면서 관심이 커졌다. 이 책은 코틀린 언어를 개발한 젯브레인의 코틀린 컴파일러 개발자들이 직접 쓴 일종의 공식 서적이라 할 수 있다. 코틀린 언어의 가장 큰 특징이라면 실용성을 들 수 있을 것이다. 이 책에서도 실용성을 강조하는 입장에서 쓰였다.
코틀린 기초를 소개하고, 고차함수, 객체지향, 제네릭스 등의 내용을 설명한다. 그리고 코틀린이 자바 언어를 어떻게 개선했고 기존 자바 프로젝트에서 코틀린을 함께 사용할 때 어떤 부분을 조심해야 할지를 중심으로 코틀린 언어를 설명한다. 후반에는 애노테이션과 리플렉션, DSL에 대해 실제 라이브러리 예제를 다루면서 설계 기법과 구현기법을 자세히 설명한다. 특히 이 주제는 이 책의 백미로, 다른 코틀린 책이나 공식 문서에서는 찾아보기 힘들며 실전에서 크게 도움이 받을 수 있다.
한국어판 부록에서는 코틀린 버전 1.3.3까지의 변화를 정리한 내용과 코루틴, 코틀린/JS에 대한 간단한 소개를 덧붙였다.

추천의 글

언어를 맨 밑바닥부터 설계하는 일은 그 자체로도 힘든 일이다. 하지만 새 언어가 기존의 다른 언어와 잘 어우러지도록 설계하는 일은 전혀 다르다. 기존 언어와 어우러지는 언어를 설계하는 과정에서 어두컴컴하고 스산한 괴물 소굴을 여럿 통과하면서 수없이 많은 힘센 괴물을 물리쳐야 한다. 자바 상호운용성은 코틀린의 가장 중요한 주춧돌이라 할 수 있으며, 이 책은 자바 코틀린 상호운용성에 신경을 많이 썼다. 이미 존재하는 자바 프로젝트에 코틀린을 점진적으로 도입할 때 자바 코틀린 상호운용성이 매우 중요하다. 심지어 새로운 프로젝트를 코틀린만으로 작성하더라도 자바로 쓰인 광범위한 라이브러리로 이뤄진 플랫폼이라는 더 큰 그림에 들어맞게 코틀린 언어를 구사해야 한다.
이 추천의 글을 쓰는 동안에도 두 가지 타겟 플랫폼을 더 개발 중이다. 이제 코틀린은 자바스크립트를 지원하기 때문에 풀 스택 웹 개발이 가능하다. 또한 빠른 시일 안에 필요에 따라 네이티브 코드로 코틀린을 컴파일해서 VM없이도 코틀린 프로그램을 실행할 수 있게 할 예정이다. 따라서 현재 이 책은 JVM에 주로 초점을 맞추지만 앞으로는 이 책에서 배운 내용을 여러 다른 실행 환경에 적용할 수 있을 것이다.
저자들은 초기부터 코틀린 팀의 일원이었기 때문에 코틀린 언어와 그 내부 구조에 대해 잘 알고 있다. 그들은 각종 컨퍼런스나 워크숍 발표, 코틀린 교육 과정 등을 통해 코틀린을 더 잘 설명할 수 있게 됐고, 사람들이 자주 하는 질문이나 흔히 저지르는 실수에 대해 더 많이 알게 됐다. 이 책은 코틀린 언어의 특성을 뒷받침하는 고수준 개념을 설명하면서도 독자들에게 필요한 만큼 각 특성의 세부 사항을 제시한다.
나는 독자 여러분이 이 책을 읽으면서 코틀린과 함께 즐거운 시간을 보내기 바란다. 내가 종종 코틀린 커뮤니티에 포스팅하면서 쓰는 인사말로 추천의 글을 마친다. 코틀린과 함께 좋은 시간 되세요!

/안드레이 브레스라프, 젠브레인 코틀린 리드 디자이너

이 책의 대상 독자

어느 정도 자바 경험이 있는 개발자를 주요 대상으로 한다. 코틀린은 자바에 있는 여러 개념과 기법 위에 만들어졌고, 이 책은 독자들이 코틀린을 빠르게 배울 수 있도록 독자들의 기존 지식을 활용한다. 자바를 배운 지 얼마 되지 않았거나 C#이나 자바 스크립트와 같은 다른 언어에 대한 경험은 있지만 자바를 잘 모르는 독자들은 코틀린과 JVM의 상호작용의 복잡한 측면을 이해하기 위해 다른 자료가 필요할 것이다. 하지만 그런 독자라도 여전히 이 책을 사용해 코틀린을 배울 수 있다. 우리는 코틀린 언어 전체를 다루며, 특별히 구체적인 영역에 초점을 맞추지는 않는다. 따라서 이 책은 서버 개발자나 안드로이드 개발자, 또는 JVM에서 실행될 프로젝트를 구축하는 모든 개발자에게 도움이 될 것이다.

이 책의 구성

이 책은 2부로 구성했고, 1부에서는 코틀린을 기존 라이브러리나 API와 함께 사용하는 방법을 설명한다.

1부는 코틀린을 기존 라이브러리나 API와 함께 사용하는 방법을 설명한다.
1장은 코틀린의 핵심 목표, 가치, 적용 영역에 대해 알려준다. 또한 코틀린 코드를 실행하는 여러 가지 방법을 보여준다.
2장은 모든 코틀린 프로그램의 핵심 요소인 제어 구조, 변수, 함수 선언 등을 설명한다.
3장은 코틀린에서 함수를 정의하는 방법을 자세히 다루고, 확장 함수(extension function)와 프로퍼티(property) 개념을 소개한다.
4장은 클래스 선언에 초점을 맞춰 설명하고, 데이터 클래스(data class)와 동반 객체(companion object)에 대해 다룬다.
5장은 코틀린 람다(lambda) 사용법을 설명하고 람다를 사용하는 코틀린 표준 라이브러리 함수를 몇 가지 보여준다.
6장은 코틀린 타입 시스템에 대해 다룬다. 특히 널 가능성(nullability)과 컬렉션에 초점을 맞춰 설명한다.

2부는 여러분 자신이 코틀린을 활용해 API를 선언하고 추상화를 정의하는 방법을 알려주고, 코틀린 언어의 더 깊은 특성을 다룬다.
7장은 관례(convention)라는 원리를 설명한다. 관례는 미리 정해진 이름인 함수나 프로퍼티에 특별한 의미를 부여한다. 또한 위임 프로퍼티(delegated property)라는 개념을 소개한다.
8장은 함수를 파라미터로 받거나 함수를 반환하는 함수인 고차 함수를 선언하는 방법을 설명한다. 또한 인라인 함수 개념을 소개한다.
9장은 코틀린 제네릭스 개념을 자세히 다룬다. 먼저 기본 문법을 설명하고 실체화한(reified) 타입 파라미터나 타입 변성(type variance)과 같은 더 어려운 주제를 설명한다.
10장은 제이키드(JKid)라는 실전에 가능한 작은 JSON 직렬화 라이브러리를 통해 애노테이션과 리플렉션 사용법을 다룬다.
11장은 영역 특화 언어 DSL 개념을 소개하고, 코틀린의 DSL 지원 기능을 설명하며, 여러 DSL예제를 살펴본다.

또한 4개의 부록이 있다.
부록 A는 그레이들(Gradle), 메이븐(Maven), 앤트(Ant)에서 코틀린 코드를 빌드하는 방법을 설명한다.
부록 B는 코틀린 모듈에 대해 문서화 주석을 사용하는 방법과 API 문서를 생성하는 방법을 알려준다.
부록 C는 코틀린 에코시스템에 있는 여러 라이브러리나 프레임워크를 소개하고 최신 정보를 온라인에서 얻는 방법을 알려준다.
부록 D~F는 한국어판에만 추가한 것으로 현재(2019년 5월)까지 코틀린의 변화를 정리하고, 코루틴과 코틀린/JS 개발에 대해 소개한다.
이 책은 전체를 차례대로 읽을 때 가장 효과가 좋다. 하지만 관심 분야를 다루는 장을 찾아서 읽거나 잘 모르는 개념을 마주칠 때 색인을 통해 필요한 부분을 찾아보면서 이 책을 활용하는 것도 좋다.

저자/역자 소개

지은이의 말

코틀린(Kotlin) 언어에 대한 아이디어는 2010년 젯브레인(JetBrains)에서 생겼다. 그 시절 젯브레인은 자바(Java), 자바스크립트(Javascript), C#, 파이썬(Python), 루비(Ruby) 등의 다양한 PHP 언어에 대한 개발 도구를 제공하는 널리 알려진 꽤 성공적인 회사였다. 젯브레인의 대표 제품인 자바 IDE 인텔리J 아이디어(IntelliJ IDEA)에는 스칼라(Scala)와 그루비(Groovy) 개발을 돕는 플러그인도 들어있었다.
이렇게 다양한 언어에 대해 도구를 개발해온 경험으로 인해 우리는 프로그래밍 언어라는 영역을 전체적으로 조망할 수 있는 독특한 시야와 이해를 가질 수 있었다. 그리고 인텔리 J 를 플랫폼으로 하는 IDE들은 인텔리J 아이디어 자체를 포함해 모두 자바로 개발되고 있었다. 우리는 모던하고 강력하며 빠르게 진화하는 언어인 C#으로 개발을 진행하는 닷넷(.Net) 팀의 동료들이 너무 부러웠다. 하지만 우리는 자바를 대신할 만한 언어를 찾을 수 없었다. 우리가 자바를 대신할 언어에 대해 어떤 요구 사항을 갖고 있었을까? 처음이자 가장 분명한 요구 사항은 정적 타입 지정(static typing)이었다. 정적 타입 지정 외에 수백만 줄이나 되는 코드 베이스를 미치지 않고 개발할 수 있는 다른 방법은 없다. 둘째로 기존 자바 코드와 완전히 호환되는 언어가 필요했다. 기존 코드베이스는 젠브레인의 엄청나게 귀중한 자산이며 상호운용성이 부족해서 그런 자산을 잃어버리거나 자산의 가치가 줄어드는 일을 용납할 수는 없었다. 셋째로 그 언어를 위한 도구 개발이 쉬워야만 했다. 우리는 도구 제공 가능성을 타협하고 싶지 않았다. 회사로서 젠브레인에게 가장 중요한 가치는 개발 생산성이며 높은 생산성을 얻기 위해서는 훌륭한 도구가 필수다. 마지막으로 배우기 쉽고 뜻을 파악하기 쉬운 언어가 필요했다.
우리 회사 내부에 이렇게 충족되지 못한 수요가 있다는 사실을 발견하던 즈음에 몇몇 회사도 우리와 비슷한 처지에 있다는 사실을 알게 됐다. 따라서 젠브레인 내부의 수요를 충족할 수 있는 솔루션을 만들면 젠브레인 밖에서도 더 많은 사용자를 찾을 수 있으리라고 예상할 수 있었다. 이를 염두에 두고 우리는 새로운 언어인 코틀린을 만드는 프로젝트를 시작하기로 결정했다. 언어를 개발하는 과정에서 처음의 예상과 달리 개발 기간이 더 늘어났고 코틀린 1.0은 최초의 저장소 커밋(repository commit) 이후 5년이 넘는 시간이 지나서 나왔다. 하지만 이제는 코틀린을 원하는 사용자를 찾았다고 확신할 수 있고 그런 사용자들이 앞으로도 계속 코틀린을 사용하리라 확신한다. 코틀린은 코틀린 개발 팀이 대부분 살고 있는 러시아의 상트페테르부르크(St. Petersburg) 근처에 있는 섬 이름이다. 섬 이름을 언어 이름으로 선택하면서 우리는 자바와 실론(Ceylon) 언어의 전통을 따랐다. 하지만 자바나 실론 대신 좀 더 고향에 가까운 섬을 택하기로 결정했다.
코틀린 정식 배포가 가까워짐에 따라 우리는 코틀린 언어를 설계하는 과정에 관여하고 코틀린 언어의 특성이 왜 현재의 모습이 되었는지에 대해 자신 있게 설명할 수 있는 사람들이 쓴 책이 한 권 있다면 사람들에게 많은 도움이 되리라 생각했다. 이 책은 그런 노력의 일환이며 독자 여러분이 이 책을 통해 코틀린 언어를 더 잘 배우고 이해하기를 바란다. 여러분의 행운과 여러분이 항상 즐겁게 개발에 매진할 수 있기를 빈다!

지은이 소개

드미트리 제메로프(Dmitry Jemerov)

2003년부터 젯브레인에서 일해 왔으며, 인텔리J 아이디어, 파이참, 웹스톰 등의 여러 제품 개발에 참여했다. 초기 코틀린 기여자 중 하나로 최초 코틀린 바이트코드 생성기를 만들었으며, 전 세계에서 코틀린 관련 발표를 진행해 왔다. 현재 코틀린 인텔리J 플러그인을 개발하는 팀을 이끌고 있다.

스베트라나 이사코바(Svetlana Isakova)

2011년부터 코틀린 팀의 일원이었다. 코틀린 컴파일러의 타입 추론과 오버로드 해결(overload resolution) 부분을 개발했다. 현재 테크니컬 에반젤리스트(technical evangelist)로서 각종 콘퍼런스에서 코틀린에 대해 알리고 코틀린 온라인 코스를 개발하고 있다.

옮긴이의 말

학교 특히 대학원에서는 컴파일러와 함수형 프로그래밍을 주로 공부했지만 회사에 들어온 후 자바와 C, C++ 개발을 10여년 진행해 왔다. 호주로 오고 나서 스칼라를 접했고 함수형 프로그래밍이라는 말이 여러 프로그래머 사이에 회자되는 모습을 보면서 격세지감을 느끼기 시작했다. 스칼라를 공부하면서 90년대 초중반 학교에서 공부했던 내용을 JVM 환경에 잘 버무린 스칼라 언어 특징을 지켜보며 스칼라를 설계한 마틴 오더스키에게 경탄했다. 스칼라가 주는 간결한 코드의 매력에 푹 빠져 계속 공부를 하면서 고차 함수를 넘어서는 타입 시스템이나 고계 타입(higher-kinded type) 등을 스칼라로 구현한 스칼라 제드나 CAT 등의 라이브러리도 살펴봤다. 타입을 활용한 강력한 추상화는 하스켈이나 스칼라 등 하드코어 함수형 프로그래밍 언어의 마약과도 같은 장점이긴 하지만, 실무에서 그런 기능으로 버무려 둔 코드가 얼마나 유지 보수성이 있을까 하는 의문이 머릿속을 떠나지 않았다. 기능을 추가하고 더 고차원적인 추상화를 가능케 하기보다는 오히려 기능을 제약하고 추상화 방법을 제한하되 초보부터 고수까지 다 이해하기 쉽고 유지보수하기 쉬운 언어를 만들어야 하는 게 아닐까? 2014년 애플이 스위프트를 발표하고, 비슷한 때 코틀린이라는 언어가 우연히 시야에 들어왔다. 두 언어는 각각 오브젝티브 C와 자바라는 언어를 개선하면서도 스칼라처럼 너무 큰 변화를 추구하지는 않는 실용적인 접근 방식을 택한 언어라는 점과, 널 가능성 처리와 람다 구문 등에서 비슷한 점이 많았다. 어쩌면 스칼라가 택한 접근 방법보다는 스위프트나 코틀린이 택한 접근 방법이 현실적으로 적용하기엔 더 쉽지 않을까 하는 생각으로 관심을 갖고 코틀린을 지켜봤다. 특히 안드로이드라는 환경이 중요하고 개발자들이 따로 공부에 투자할 시간이 절대적으로 부족한 한국의 현실에서는 코틀린이 더욱 쓸모가 있을 것 같았다. 그리고 코틀린이 2017년 안드로이드 공식 언어가 되면서 한국에서도 코틀린에 대한 관심이 폭발적으로 늘어나는 모습을 볼 수 있었다.
언어적으로 볼 때 코틀린은 그다지 새로운 언어가 아니다. 코틀린이 제공하는 여러 기능을 살펴보면 정말 자바를 개선하기 위해 많은 부분에서 고민을 했다는 느낌이 많이 든다. 학술적으로 가치가 있거나 소위 힙스터 프로그래머들의 관심을 끌 만한 기능은 거의 없다. 함수를 표현하는 인터페이스로 데이터 타입이나 함수를 표현해서 객체지향과 통합하는 방법 등은 이제 다양한 언어에서 채용하고 있는 잘 알려진 기법이다. 모나드를 쉽게 활용할 수 있게 해주는 for 컴프리핸션이나 패턴 매치, 고계 타입(higher-kindedtype) 등 함수형 프로그래밍 언어에서는 당연히 제공하는 기능도 아직 제공하지 않는다.
하지만 ‘방망이 깎던 노인’이 방망이를 깎던 것처럼 여러 해 동안 실제 IDE 개발에 코틀린을 사용하면서 얻은 피드백을 바탕으로 이해하기 쉽고 개발자 손에 착 달라붙으면서도 기존 자바 소스와 함께 사용하기 편리한 언어를 만들어냈다. 코틀린이 자바에 추가한 여러 기능은 커다란 추가 런타임 라이브러리가 필요할 정도로 양이 많지는 않지만, 자바의 가려움을 긁어줄 만한 내용들이 들어있다. 그러면서도 너무 복잡하거나 너무 어렵지는 않아 다양한 수준의 개발자가 함께 참여해야 하는 실전 프로젝트에서 사용하기에 딱 좋다. 게다가 기존 자바 라이브러리와의 호환성을 중시하면서 개발해 왔기 때문에 상대적으로 JVM에서 기존 자바 에코시스템을 활용하기 쉽다는 장점도 있다. 어쩌면 코틀린은 최신 언어라고 부르기엔 너무 구식 특성만을 가진 언어일지도 모른다. 그러나 대규모 개발과 유지 보수성, 기존 자바 시스템과의 호환성 등을 고려해본다면 가장 강력한 자바 대체재라고 볼 수 있다.
이 책은 코틀린 언어를 개발하는 젠브레인 개발자가 직접 쓴 책이다. 물론 이 책은 코틀린에 대해 자세히 설명한다. 그런데 코틀린의 특성을 설명할 때마다 그 특성을 자바 쪽에서는 어떻게 사용해야 하고, 이때 어떤 주의 사항이 있는지 설명한다는 점이 특이하다. 이는 코틀린을 설계한 사람들의 머릿속에 자바 호환성이 아주 중요하게 자리 잡고 있음을 보여준다. 한편 이 책은 코틀린 기능들이 서로 어떻게 연관되고 이를 어떻게 활용할 수 있는지 설명해준다. 특히 확장 함수와 수신 객체 지정 람다, 그리고 그런 기능을 DSL에 적용하는 모습을 살펴보면 한편의 아름다운 시를 볼 때처럼 아름다움을 느낄 수 있다. 여러분도 이 책을 읽고 나면 비슷한 느낌을 받을 수 있을 것이다.
아무쪼록 이 책을 통해 코틀린이 여러분 손에 착 달라붙는 제대로 깎은 방망이처럼 작업할 때 편하게 사용할 수 있는 도구로 자리 잡길 바란다. 그리고 코틀린을 통해 늘어난 생산성만큼 독자 여러분이 좀 더 여유 있는 저녁이 있는 삶을 누릴 수 있게 되길 바란다.

옮긴이 소개

오현석

KAIST에서 전산학 학사와 석사 학위(프로그래밍 언어 연구실)를 취득했다. 삼성메디슨, 비트앤펄스 등에서 UI 개발자와 개발 팀장을 지냈고, 현재 호주 JNF Soft에서 C++/풀스택 개발자 및 컨설턴트로 일하고 있다. 매일 두 시간씩 번역과 저술을 통해 조금이나마 동료 프로그래머들에게 도움을 주고자 노력하고 있다. 웹이나 모바일 등의 분야에서 값 중심 프로그래밍을 통해 오류 발생 가능성이 적으면서 유지 보수가 편한 프로그램을 작성하는 방법과 이를 지원하는 여러 도구를 만드는 일에 관심이 많다. 최근에는 CEF를 기반으로 웹 프론트엔드와 C++ 백엔드를 결합한 흥미로운 프로젝트를 진행 중이며, 함수형 리액티브 프로그래밍을 자바스크립트와 C++에 적용해 좀 더 편하면서 오류도 적은 코드를 생산해내는 방법을 찾으려고 고민 중이다.
『코어 파이썬 애플리케이션 프로그래밍 Third Edition』(에이콘, 2014), 『함수형 파이썬 프로그래밍』 (에이콘, 2017), 『Programming in Scala 3/e』(에이콘, 2017), 『함수형 반응형 프로그래밍』(한빛미디어, 2017), 『Akka 코딩 공작소』(길벗, 2017) 등을 비롯한 십여 권 이상의 책을 번역했다.

목차

목차
  • 1장. 코틀린이란 무엇이며, 왜 필요한가?
    • 1.1 코틀린 맛보기
    • 1.2 코틀린의 주요 특성
      • 1.2.1 대상 플랫폼: 서버, 안드로이드 등 자바가 실행되는 모든 곳
      • 1.2.2 정적 타입 지정 언어
      • 1.2.3 함수형 프로그래밍과 객체지향 프로그래밍
      • 1.2.4 무료 오픈소스
    • 1.3 코틀린 응용
      • 1.3.1 코틀린 서버 프로그래밍
      • 1.3.2 코틀린 안드로이드 프로그래밍
    • 1.4 코틀린의 철학
      • 1.4.1실용성
      • 1.4.2간결성
      • 1.4.3 안전성
      • 1.4.4 상호운용성
    • 1.5 코틀린 도구 사용
      • 1.5.1 코틀린 코드 컴파일
      • 1.5.2 인텔리J 아이디어와 안드로이드 스튜디오의 코틀린 플러그인
      • 1.5.3 대화형 셸
      • 1.5.4 이클립스 플러그인
      • 1.5.5 온라인 놀이터
      • 1.5.6 자바-코틀린 변환기
    • 1.6요약

  • 2장. 코틀린 기초
    • 2.1 기본 요소: 함수와 변수
      • 2.1.1 Hello, World!
      • 2.1.2 함수
      • 2.1.3 변수
      • 2.1.4 더 쉽게 문자열 형식 지정: 문자열 템플릿
    • 2.2 클래스와 프로퍼티
      • 2.2.1 프로퍼티
      • 2.2.2 커스텀 접근자
      • 2.2.3 코틀린 소스코드 구조: 디렉터리와 패키지
    • 2.3 선택의 표현과 처리: enum과 when
      • 2.3.1 enum 클래스 정의
      • 2.3.2 when으로 enum 클래스 다루기
      • 2.3.3 when과 임의의 객체를 함께 사용
      • 2.3.4 인자 없는 when 사용
      • 2.3.5 스마트 캐스트: 타입 검사와 타입 캐스트를 조합
      • 2.3.6 리팩토링: if를 when으로 변경
      • 2.3.7 if와 when의 분기에서 블록 사용
    • 2.4 대상을 이터레이션: while과 for 루프
      • 2.4.1 while 루프
      • 2.4.2 숫자에 대한 이터레이션: 범위와 수열
      • 2.4.3 맵에 대한 이터레이션
      • 2.4.4 in으로 컬렉션이나 범위의 원소 검사
    • 2.5 코틀린의 예외 처리
      • 2.5.1 try, catch, finally
      • 2.5.2 try를 식으로 사용
    • 2.6 요약

  • 3장. 함수 정의와 호출
    • 3.1 코틀린에서 컬렉션 만들기
    • 3.2 함수를 호출하기 쉽게 만들기
      • 3.2.1 이름 붙인 인자
      • 3.2.2 디폴트 파라미터 값
      • 3.2.3 정적인 유틸리티 클래스 없애기: 최상위 함수와 프로퍼티
      • 3.3 메소드를 다른 클래스에 추가: 확장 함수와 확장 프로퍼티
      • 3.3.1 임포트와 확장 함수
      • 3.3.2 자바에서 확장 함수 호출
      • 3.3.3 확장 함수로 유틸리티 함수 정의
      • 3.3.4 확장 함수는 오버라이드 할 수 없다
      • 3.3.5 확장 프로퍼티
    • 3.4 컬렉션 처리: 가변 길이 인자, 중위 함수 호출, 라이브러리 지원
      • 3.4.1 자바 컬렉션 API 확장
      • 3.4.2 가변인자 함수: 인자의 개수가 달라질 수 있는 함수 정의
      • 3.4.3 값의 쌍 다루기: 중위 호출과 구조 분해 선언
    • 3.5 문자열과 정규식 다루기
      • 3.5.1 문자열 나누기
      • 3.5.2 정규식과 3중 따옴표로 묶은 문자열
      • 3.5.3 여러 줄 3중 따옴표 문자열
    • 3.6 코드 다듬기: 로컬 함수와 확장
    • 3.7 요약

  • 4장. 클래스, 객체, 인터페이스
    • 4.1 클래스 계층 정의
      • 4.1.2 코틀린 인터페이스
      • 4.1.2 open, final, abstract 변경자: 기본적으로 final
      • 4.1.3 가시성 변경자: 기본적으로 공개
      • 4.1.4 내부 클래스와 중첩된 클래스: 기본적으로 중첩 클래스
      • 4.1.5 봉인된 클래스: 클래스 계층 정의 시 계층 확장 제한
    • 4.2 뻔하지 않은 생성자와 프로퍼티를 갖는 클래스 선언
      • 4.2.1 클래스 초기화: 주 생성자와 초기화 블록
      • 4.2.2 부 생성자: 상위 클래스를 다른 방식으로 초기화
      • 4.2.3 인터페이스에 선언된 프로퍼티 구현
      • 4.2.4 게터와 세터에서 뒷받침하는 필드에 접근
      • 4.2.5 접근자의 가시성 변경
    • 4.3 컴파일러가 생성한 메소드: 데이터 클래스와 클래스 위임
      • 4.3.1 모든 클래스가 정의해야 하는 메소드
      • 4.3.2 데이터 클래스: 모든 클래스가 정의해야 하는 메소드 자동 생성
      • 4.3.3 클래스 위임: by 키워드 사용
    • 4.4 object 키워드: 클래스 선언과 인스턴스 생성
      • 4.4.1 객체 선언: 싱글턴을 쉽게 만들기
      • 4.4.2 동반 객체: 팩터리 메소드와 정적 멤버가 들어갈 장소
      • 4.4.3 동반 객체를 일반 객체처럼 사용
      • 4.4.4 객체 식: 익명 내부 클래스를 다른 방식으로 작성
    • 4.5 요약

  • 5장. 람다로 프로그래밍
    • 5.1 람다 식과 멤버 참조
      • 5.1.1 람다 소개: 코드 블록을 함수 인자로 넘기기
      • 5.1.2 람다와 컬렉션
      • 5.1.3 람다 식의 문법
      • 5.1.4 현재 영역에 있는 변수에 접근
      • 5.1.5 멤버 참조
    • 5.2 컬렉션 함수형 API
      • 5.2.1 필수적인 함수: filter와 map
      • 5.2.2 all, any, count, find: 컬렉션에 술어 적용
      • 5.2.3 groupBy: 리스트를 여러 그룹으로 이뤄진 맵으로 변경
      • 5.2.4 flatMap과 flatten: 중첩된 컬렉션 안의 원소 처리
    • 5.3 지연 계산 lazy 컬렉션 연산
      • 5.3.1 시퀀스 연산 실행: 중간 연산과 최종 연산
      • 5.3.2 시퀀스 만들기
    • 5.4 자바 함수형 인터페이스 활용
      • 5.4.1 자바 메소드에 람다를 인자로 전달
      • 5.4.2 SAM 생성자: 람다를 함수형 인터페이스로 명시적으로 변경
    • 5.5 수신 객체 지정 람다: with와 apply
      • 5.5.1 with함수
      • 5.5.2 apply함수
    • 5.6 요약

  • 6장. 코틀린 타입 시스템
    • 6.1 널 가능성
      • 6.1.1 널이 될 수 있는 타입
      • 6.1.2 타입의 의미
      • 6.1.3 안전한 호출 연산자: "?."
      • 6.1.4 엘비스 연산자 "?:"
      • 6.1.5 안전한 캐스트: as?
      • 6.1.6 널 아님 단언: !!
      • 6.1.7 let함수
      • 6.1.8 나중에 초기화할 프로퍼티
      • 6.1.9 널이 될 수 있는 타입 확장
      • 6.1.10 타입 파라미터의 널 가능성
      • 6.1.11 널 가능성과 자바
    • 6.2 코틀린의 기본 타입
      • 6.2.1 기본 타입: Int, Boolean 등
      • 6.2.2 널이 될 수 있는 기본 타입: Int?, Boolean? 등
      • 6.2.3 숫자 변환
      • 6.2.4 Any, Any?: 최상위 타입
      • 6.2.5 Unit 타입: 코틀린의 void
      • 6.2.6 Nothing 타입: “이 함수는 결코 정상적으로 끝나지 않는다.”
    • 6.3 컬렉션과 배열
      • 6.3.1 널 가능성과 컬렉션
      • 6.3.2 읽기 전용과 변경 가능한 컬렉션
      • 6.3.3 코틀린 컬렉션과 자바
      • 6.3.4 컬렉션을 플랫폼 타입으로 다루기
      • 6.3.5 객체의 배열과 기본 타입의 배열
    • 6.4요약

  • 2부. 코틀린답게 사용하기
  • 7장. 연산자 오버로딩과 기타 관례
    • 7.1 산술 연산자 오버로드
      • 7.1.1 이항 산술 연산 오버로딩
      • 7.1.2 복합 대입 연산자 오버로딩
      • 7.1.3 단항 연산자 오버로딩
    • 7.2 비교 연산자 오버로딩
      • 7.2.1 동등성 연산자: "equals"
      • 7.2.2 순서 연산자: compareTo
      • 7.3 컬렉션과 범위에 대해 쓸 수 있는 관례
      • 7.3.1 인덱스로 원소에 접근: get과 set
    • 7.3.3 in관례
      • 7.3.3 rangeTo관례
      • 7.3.4 for 루프를 위한 iterator 관례
    • 7.4 구조 분해 선언과 component 함수
      • 7.4.1 구조 분해 선언과 루프
    • 7.5 프로퍼티 접근자 로직 재활용: 위임 프로퍼티
      • 7.5.1 위임 프로퍼티 소개
      • 7.5.2 위임 프로퍼티 사용: by lazy()를 사용한 프로퍼티 초기화 지연
      • 7.5.3 위임 프로퍼티 구현
      • 7.5.4 위임 프로퍼티 컴파일 규칙
      • 7.5.5 프로퍼티 값을 맵에 저장
      • 7.5.6 프레임워크에서 위임 프로퍼티 활용
    • 7.6 요약

  • 8장. 고차 함수: 파라미터와 반환 값으로 람다 사용
    • 8.1 고차 함수 정의
      • 8.1.1 함수 타입
      • 8.1.2 인자로 받은 함수 호출
      • 8.1.3 자바에서 코틀린 함수 타입 사용
      • 8.1.4 디폴트 값을 지정한 함수 타입 파라미터나 널이 될 수 있는 함수 타입 파라미터
      • 8.1.5 함수를 함수에서 반환
      • 8.1.6 람다를 활용한 중복 제거
    • 8.2 인라인 함수: 람다의 부가 비용 없애기
      • 8.2.1 인라이닝이 작동하는 방식
      • 8.2.2 인라인 함수의 한계
      • 8.2.3 컬렉션 연산 인라이닝
      • 8.2.4 함수를 인라인으로 선언해야 하는 경우
      • 8.2.5 자원 관리를 위해 인라인된 람다 사용
    • 8.3 고차 함수 안에서 흐름 제어
      • 8.3.1 람다 안의 return문: 람다를 둘러싼 함수로부터 반환
      • 8.3.2 람다로부터 반환: 레이블을 사용한 return
      • 8.3.3 무명 함수: 기본적으로 로컬 return
    • 8.4 요약

  • 9장. 제네릭스
    • 9.1 제네릭 타입 파라미터
      • 9.1.1 제네릭 함수와 프로퍼티
      • 9.1.2 제네릭 클래스 선언
      • 9.1.3 타입 파라미터 제약
      • 9.1.4 타입 파라미터를 널이 될 수 없는 타입으로 한정
    • 9.2 실행 시 제네릭스의 동작: 소거된 타입 파라미터와 실체화된 타입 파라미터
      • 9.2.1 실행 시점의 제네릭: 타입 검사와 캐스트
      • 9.2.2 실체화한 타입 파라미터를 사용한 함수 선언
      • 9.2.3 실체화한 타입 파라미터로 클래스 참조 대신
      • 9.2.4 실체화한 타입 파라미터의 제약
    • 9.3 변성: 제네릭과 하위 타입
      • 9.3.1 변성이 있는 이유: 인자를 함수에 넘기기
      • 9.3.2 클래스, 타입, 하위 타입
      • 9.3.3 공변성: 하위 타입 관계를 유지
      • 9.3.4 반공변성: 뒤집힌 하위 타입 관계
      • 9.3.5 사용 지점 변성: 타입이 언급되는 지점에서 변성 지정
      • 9.3.6 스타 프로젝션: 타입 인자 대신 * 사용
    • 9.4 요약

  • 10장. 애노테이션과 리플렉션
    • 10.1 애노테이션 선언과 적용
      • 10.1.2 애노테이션 대상
      • 10.1.3 애노테이션을 활용한 JSON 직렬화 제어
      • 10.1.4 애노테이션 선언
      • 10.1.5 메타애노테이션: 애노테이션을 처리하는 방법 제어
      • 10.1.6 애노테이션 파라미터로 클래스 사용
      • 10.1.7 애노테이션 파라미터로 제네릭 클래스 받기
    • 10.2 리플렉션: 실행 시점에 코틀린 객체 내부 관찰
      • 10.2.1 코틀린 리플렉션 API: KClass, KCallable, KFunction, KProperty
      • 10.2.2 리플렉션을 사용한 객체 직렬화 구현
      • 10.2.3 애노테이션을 활용한 직렬화 제어
      • 10.2.4 JSON 파싱과 객체 역직렬화
      • 10.2.5 최종 역직렬화 단계: callBy(), 리플렉션을 사용해 객체 만들기
    • 10.3 요약

  • 11장. DSL 만들기
    • 11.1 API에서 DSL로
      • 11.1.1 영역 특화 언어라는 개념
      • 11.1.2 내부 DSL
      • 11.1.3 DSL의 구조
      • 11.1.4 내부 DSL로 HTML 만들기
    • 11.2 구조화된 API 구축: DSL에서 수신 객체 지정 DSL 사용
      • 11.2.1 수신 객체 지정 람다와 확장 함수 타입
      • 11.2.2 수신 객체 지정 람다를 HTML 빌더 안에서 사용
      • 11.2.3 코틀린 빌더: 추상화와 재사용을 가능하게 하는 도구
    • 11.3 invoke 관례를 사용한 더 유연한 블록 중첩
      • 11.3.1 invoke 관례: 함수처럼 호출할 수 있는 객체
      • 11.3.2 invoke 관례와 함수형 타입
      • 11.3.3 DSL의 invoke 관례: 그레이들에서 의존관계 정의
    • 11.4 실전 코틀린 DSL
      • 11.4.1 중위 호출 연쇄: 테스트 프레임워크의 should
      • 11.4.2 기본 타입에 대한 확장 함수 정의: 날짜 처리
      • 11.4.3 멤버 확장 함수: SQL을 위한 내부 DSL
      • 11.4.4 안코: 안드로이드 UI를 동적으로 생성하기
    • 11.5 요약

  • 부록 A. 코틀린 프로젝트 빌드
    • A.1 그레이들로 코틀린 코드 빌드
    • A.2 메이븐으로 코틀린 프로젝트 빌드
    • A.3 앤트로 코틀린 코드 빌드

  • 부록 B. 코틀린 코드 문서화
    • B.1 코틀린 문서화 주석 작성
    • B.2 API 문서 생성

  • 부록 C. 코틀린 에코시스템
    • C.1 테스팅
    • C.2 의존관계 주입
    • C.3 JSON 직렬화
    • C.4 HTTP 클라이언트
    • C.5 웹 애플리케이션
    • C.6 데이터베이스 접근
    • C.7 유틸리티와 데이터 구조
    • C.8 데스크탑 프로그래밍

  • 부록 D. 코틀린 1.1과 1.2, 1.3 소개
    • D.1 코틀린 1.1
    • D.2 코틀린 1.2
    • D.3 코틀린 1.3

  • 부록 E. 코루틴과 Async/Await
    • E.1 코루틴이란?
    • E.2 코틀린의 코루틴 지원: 일반적인 코루틴
    • E.3 suspend 키워드와 코틀린의 일시 중단 함수 컴파일 방법
    • E.4 코루틴 빌더 만들기
    • E.5 결론

  • 부록 F. 코틀린/JS
    • F.1 코틀린/JS 프로젝트 기본 설정
    • F.2 Hello, World!
    • F.3 코틀린에서 DOM에 접근
    • F.4 js() 함수와 dynamic 타입, external 변환자
    • F.5 자바스크립트에서 코틀린 호출
    • F.6 복잡한 예제: HTML 빌더, jQuery 라이브러리 사용 예제
    • F.7 외부 라이브러리에 대한 코틀린/JS 래퍼
    • F.8 결론

도서 오류 신고

도서 오류 신고

에이콘출판사에 관심을 가져 주셔서 고맙습니다. 도서의 오탈자 정보를 알려주시면 다음 개정판 인쇄 시 반영하겠습니다.

오탈자 정보는 다음과 같이 입력해 주시면 됩니다.

(예시) p.100 아래에서 3행 : '몇일'동안 -> 며칠동안

정오표

정오표

Kotlin 1.5 대응판 수정사항

[p.31 : 아래에서 6~7행]
http://www.manning.com/books/kotlin-inaction
->
http://www.manning.com/books/kotlin-in-action

[p.600 : 위에서 4행]
두 함ㅅ
->
두 함수

[p.600 ~ 601]
Deffered
->
Deferred

Kotlin 1.3 대응판 수정사항

[p.30 : 15행]
코루틴에 대해 소게한다.
->
코루틴에 대해 소개한다.

[p.256 : 그림 6.5]
널 아님 단언을 사용하면 값이 널이 아닐 때 NPE를 던질 수 있다.
->
널 아님 단언을 사용하면 값이 널일 때 NPE를 던질 수 있다.

[p.331 : 3번째 문단 코드 설명]
getValue와 getValue 메소드를 호출한다.
->
getValue와 setValue 메소드를 호출한다.

[p.349 : 아래에서 5행]
var canReturnNull: (Int, Int) -> Int? = {x, y => null }
->
var canReturnNull: (Int, Int) -> Int? = {x, y -> null }

Kotlin 1.2 초판 수정사항

[p.31 : 아래에서 4행]
행동 강력
->
행동 강령

[p.92 : 3행]
setp
->
step

[p.117]

->
한 파일 안에서 다른 여러 패키지에 속해있는 이름이 같은 함수를 가져와 사용해야 하는 경우, 이름을 바꿔서 임포트하면 이름 충돌을 막을 수 있다. 물론 일반적인 클래스나 함수라면 그 전체 이름(FQN, Fully Qualified Name)을 써도 된다. 하지만 코틀린 문법상 확장 함수는 반드시 짧은 이름을 써야 한다. 따라서 임포트할 때 이름을 바꾸는 것이 확장 함수 이름 충돌을 해결할 수 있는 유일한 방법이다.

[p.133 : 아래에서 2행]
에는 사용하면
->
에는

[ p.146 : 박스 6행 ]
그러므로 디폴트 인터페이스가 포함된 코틀린 인터페이스를
->
그러므로 디폴트 메서드가 포함된 코틀린 인터페이스를

[p.148 : 2행]
오버라이하는 메소드의
->
오버라이드하는 메소드의

[p.148 : 아래에서 4행]
추상 클래스에는 추상 멤버가 있어서 상속할 수 없고
->
추상 클래스에는 구현을 갖지 않는 추상 멤버가 있기 때문에

[p.172 : 위에서 4행]
자바와 마찬가지로 모든 코틀린 클래스는 toString, equals, hashCode 등을 오버라이드해야 한다.
->
자바와 마찬가지로 코틀린 클래스도 toString, equals, hashCode 등을 오버라이드할 수 있다.

[p.218 : 아래에서 3행]
모든 원소가 3인은 아니라는 뜻이다.
->
모든 원소가 3인 것은 아니라는 뜻이다

[p. 241 : 2행]
인스터스
->
인스턴스

[p.241 : 12행]
StringBuidler
->
StringBuilder

[p.280 : 9행]
타임
->
타입

[p.298 : 6행]
파리미터
->
파라미터

[p.312 : 아래에서 2행]
변경 기능한 클래스
->
변경 가능한 클래스

[p.584]
함ㅅ의 구현을 보면
->
함수의 구현을 보면

[p.586]
실해해보자.
->
실행해보자.