코틀린 & Java/코틀린인액션 18

[Kotlin] 코틀린이란 무엇이며, 왜 필요한가?

코틀린이란? 자바 플랫폼에서 돌아가는 프로그래밍 언어 자바와의 상호운용성에 초점을 맞춘 실용적이고 간결하며 안전한 언어 대상 플랫폼 서버 (backend) 안드로이드 모바일 애플리케이션 등등 (iOS, 자바스크립트…) 코틀린은 정적 타입(statically typed) 지정 언어 정적 타입 지정 언어? : 프로그램 구성 요소의 타입을 컴파일 시점에 알 수 있고, 필드나 메소드 사용 시 컴파일러가 타입을 검증해준다. 동적 타입 지정 언어? : 타입 관계없이 모든 값을 변수에 넣을 수 있고, 실행 시점에 필드나 메소드에 대한 검증한다. (Groovy, JRuby 등) 정적 타입 지정 언어 장점 성능 : 컴파일 시점에 메소드 호출 여부를 알고 있어서 빠르다. 신뢰성 : 컴파일러가 컴파일 시점에 프로그램의 정확..

[Kotlin] 기본 요소 함수와 변수에 대해 알아보자 (1)

코틀린에서 타입 선언을 생략해도 된다. # 코틀린 특징 코틀린 표준 라이브러리는 여러가지 표준 자바 라이브러리 함수를 간결하게 사용할 수 있게 감싼 래퍼(wrapper)를 제공 줄 끝에 세미콜론(;)을 붙이지 않아도 된다. if는(값을 만들어내지 못하는 문장이 아니고 결과를 만드는 식) 문(statement)과 식(expression) 식은 값을 만들어 내며 다른 식의 하위 요소로 계산에 참여할 수 있다. 문은 가장 안쪽 블록의 최상위 요소로 존재, 아무런 값을 만들어내지 않는다. 코틀린은 루프를 제외한 대부분의 제어 구조가 식이다 자바는 모든 제어 구조가 문이다 반면 대입문은 자바에서는 식이었으나, 코틀린에서는 문이 됐다. # 함수 fun max(a: Int, b: Int): Int { } 함수를 선언..

[Kotlin] 기본 요소 함수와 변수에 대해 알아보자 (2)

함수와 변수 #While 루프 while (조건) { /*...*/ //조건이 참인 동안 본문을 반복 실행한다. } do { /*...*/ } while (조건) //맨 처음에 무조건 본문을 한 번 실행한 다음, 조건이 참인 동안 본문을 반복 실행한다. #범위와 수열 자바의 for 루프(어떤 변수를 초기화하고 그 변수를 루프가 한 번 실행할 때마다 갱신하고 루프 조건이 거짓이 될 때 반복을 마치는 형태의 루프)에 해당하는 요소가 없다. 이를 대신하기 위해 코틀린에서는 **범위(range)**를 이용한다. fun fizzBuzz(i: Int) = when { i % 15 == 0 -> "FizzBuzz" i % 3 == 0 -> "Fizz" i % 5 == 0 -> "Buzz" else -> "$i" } ..

[Kotlin] 코틀린 함수 정의와 호출

코틀린 함수 정의와 호출 코틀린이 자체 컬렉션을 제공하지 않는 이유? - 자바 코드와 상호작용하기가 훨씬 더 쉽다. # 이름 붙인 인자 함수 호출 부분의 가독성 함수에 전달하는 인자 중 일부(또는 전부)의 이름을 명시할 수 있다. 하나라도 이름을 명시하면 뒤에 오는 모든 인자는 이름을 명시 해야 한다. # 디폴트 파라미터 값 함수 선언에서 파라미터의 디폴트 값을 지정할 수 있으므로 이런 오버로드 중 상당수를 피할 수 있다. # 최상위 프로퍼티 함수와 마찬가지로 프로퍼티도 파일의 최상위 수준에 놓을 수 있다. 이런 프로퍼티의 값은 정적 필드에 저장 된다. 더 자연스럽게 사용하려면 이 상수를 public static final 필드로 컴파일해야 한다. const변경자를 추가하면 된다. # 확장 함수와 확장 ..

[Kotlin] 클래스, 객체, 인터페이스에 대해 알아보자(1)

코틀린의 클래스와 인터페이스는 자바와는 약간 다르다 인터페이스에 프로퍼티 선언이 들어갈 수 있다. 코틀린 선언은 기본적으로 final이며 public이다. 중첩 클래스는 내부 클래스가 아니다. 즉, 코틀린 중첩 클래스에는 외부 클래스에 대한 참조가 없다. 코틀린 컴파일러는 유용한 메서드를 자동으로 만들어 준다. 클래스를 data로 선언하면 일부 표준 메서드를 생성해준다. object키워드 : 클래스와 인스턴스를 동시에 선언 싱글턴 클래스, 동반객체(companion object), 객체 식(object expression(자바의 무명클래스) 코틀린 언어가 제공하는 위임(delegation)을 사용하면 준비 메서드를 직접 작성할 필요가 없다. Delegation 이란? by 키워드를 활용한 Properti..

[Kotlin] 클래스, 객체, 인터페이스에 대해 알아보자 (2)

Kotlin 클래스, 객체, 인터페이스 Any class The root of the Kotlin class hierarchy. Every Kotlin class has Any as a superclass. open function으로 equals, hashCode, toString을 제공 equals, hashCode, toString 코틀린 컴파일러가 보이지 않는 곳에서 생성해 준다. 문자열 표현: toString() 인스턴스의 문자열 표현 제공 디버깅과 로깅 시 사용 객체의 동등성: equals() 자바 equals 객체의 동등성 자바 ‘==’ 원시 타입 에서는 값 비교 참조 타입 에서는 주소 비교 코틀린 ‘==’ 내부적으로 equals를 호출 객체의 동등성 값 비교 코틀린 ‘===’ 주소 비교 참..

인라인 함수: 람다의 부가 비용 없애기

인라인 함수: 람다의 부가 비용 없애기 람다가 변수를 포획하면 람다가 생성되는 시점마다 새로운 무명 클래스 객체가 생긴다. 이런경우, 실행 시점에 무명 클래스 생성에 따른 부가 비용이 든다. → 똑같은 작업을 수행하는 일반 함수를 사용한 구현보다 덜 효율적 inline 변경자 컴파일러는 그 함수를 호출하는 모든 문장을 함수 본문에 해당하는 바이트 코드로 바꿔치기 해준다. 작동 방식 함수를 호출하는 코드를 함수를 호출하는 바이트코드 대신에 함수 본문을 번역한 바이트 코드로 컴파일한다. [Kotlin in Action 책] p.365 8.13~8.3 synchronized 함수의 본문뿐 아니라 전달된 람다의 본문도 함께 인라이닝 된다. 함수 타입의 변수를 넘길수도 있다. fun runUnderLock(bod..

고차 함수 정의

고차 함수 (High order function) 다른 함수를 인자로 받거나 함수를 반환하는 함수 함수 타입 val sum: (Int, Int) -> Int = { x, y -> x+y } val action: () -> Unit = { println(42) } 함수 타입을 정의하려면 함수 파라미터의 타입을 괄호 안에 넣고, 그뒤에 화살표(→)를 추가한 다음, 반환 타입을 지정하면 된다. 함수타입을 선언할 때는 반환 타입으로 반드시 명시해야 하므로 Unit을 빼먹어서는 안 된다. 반환 타입이 널이 될 수 있는 타입 var canReturnNull: (Int, Int) -> Int? = {x, y -> null} 함수 타입 전체가 널이 될 수 있는 타입 var funOrNull: ((Int, Int) ->..

delegated property 프로퍼티 접근자 로직 재활용

프로퍼티 접근자 로직 재활용 위임 프로퍼티(delegated property) 값을 뒷받침하는 필드에 단순히 저장하는 것보다 더 복잡한 방식으로 작동하는 프로퍼티를 쉽게 구현할 수 있다. 프로퍼티는 위임을 사용해 자신의 값을 필드가 아니라 데이터베이스 테이블이나 브라우저 세션, 맵 등에 저장할 수 있다. 위임은 객체가 직접 작업을 수행하지 않고 다른 도우미 객체가 그 작업을 처리하게 맡기는 디자인 패턴을 말한다. 이때 작업을 처리하는 도우미 객체를 위임 객체라고 부른다. class Delegate { operator fun getValue(...) {...} //getValue는 게터를 구현하는 로직을 담는다. operator fun setValue(..., value: Type) {...} // set..

Kotlin 구조 분해 선언과 component 함수(Pair, Triple)

구조 분해 선언과 component 함수 구조 분해 선언(destructuring declaration) >>> val p = Point(10, 20) >>> val (x, y) = p // x와 y 변수를 선언한 다음에 p와 여러 컴포넌트로 초기화 >>> println(x) 10 >>> println(y) 20 구조 분해 선언의 각 변수를 초기화하기 위해 componentN 이라는 함수를 호출한다. class Point(val x: Int, val y: Int){ operator fun component1() = x operator fun component2() = y } 여러 값을 한꺼번에 반환해야 하는 함수는 구조 분해 선언 구문을 사용하면 쉽게 풀어서 여러 변수를 넣을 수있다. //값을 저장하기 ..