반응형
Notice
Recent Posts
Recent Comments
Link
«   2025/01   »
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
Tags
more
Archives
Today
Total
관리 메뉴

안드로이드 개발자 노트

[이펙티브 코틀린] Item23. 타입 파라미터의 섀도잉을 피하라 본문

Kotlin/이펙티브 코틀린

[이펙티브 코틀린] Item23. 타입 파라미터의 섀도잉을 피하라

어리둥절범고래 2023. 11. 11. 19:55
반응형

다음 코드처럼 프로퍼티와 파라미터가 같은 이름을 가질 수 있습니다.

class Forest(name: String) {
    fun addTree(name: String) {
        //...
    }
}

 

이렇게 되면 지역 파라미터가 외부 스코프에 있는 프로퍼티를 가리게되며, 이를 섀도잉이라고 부릅니다.

섀도잉 현상은 클래스 타입 파라미터와 함수 타입 파라미터 사이에서도 발생합니다.

interface Tree
class Birch : Tree
class Sqruce : Tree

class Forest<T : Tree> {

    fun <T : Tree> addTree(tree: T) {
        //...
    }
}

 

이렇게 코드를 작성하면, Forest와 addTree의 타입 파라미터가 독립적으로 동작합니다.

val forest = Forest<Birch>()
forest.addTree(Birch())
forest.addTree(Sqruce())

 

코드만 봐서는 addTree 함수의 타입 파라미터와 Forest 클래스의 타입 파라미터 둘이 독립적으로 동작한다는 것을 빠르게 알아내기 힘듭니다.

따라서 addTree가 클래스 타입 파라미터인 T를 사용하게 하는 것이 좋습니다.

class Forest<T : Tree> {

    fun addTree(tree: T) {
        //...
    }
}

// Usage
val forest = Forest<Birch>()
forest.addTree(Birch())
forest.addTree(Sqruce()) // Error, type mismatch

 

독립적인 타입 파라미터를 의도한다면, 이름을 아예 다르게 다는 것이 좋습니다.

또한, 다음 코드처럼 타입 파라미터를 사용해서 다른 타입 파라미터에 제한을 줄 수도 있습니다.

class Forest<T : Tree> {

    fun <ST : Tree> addTree(tree: ST) {
        //...
    }
}

 

 

 


정리

 

  • 타입 파라미터 섀도잉을 피하라. 타입 파라미터 섀도잉이 발생한 코드는 이해하기 어려울 수 있다.
반응형