문제

Reuse your solution from the previous task, but replace the interface with the sealed interface. Then you no longer need the else branch in when.

fun eval(expr: Expr): Int =
        when (expr) {
            is Num -> TODO()
            is Sum -> TODO()
        }

interface Expr
class Num(val value: Int) : TODO()
class Sum(val left: Expr, val right: Expr) : TODO()

fun eval(expr: Expr): Int =
        when (expr) {
            is Num -> expr.value
            is Sum -> eval(expr.left) + eval(expr.right)
        }

sealed interface Expr
class Num(val value: Int) : Expr
class Sum(val left: Expr, val right: Expr) : Expr

풀이

인터페이스를 sealed interface로 교체하는 문제이다.

Sealed 클래스

  • sealed 클래스는 영어 단어 뜻 그대로 몇몇 타입을 묶기(밀봉) 위한 용도로 사용하며, sealed 예약어로 선언한다.
  • 다른 클래스가 상속을 받지 못하도록 제한하는 클래스이다.
  • sealed 클래스의 사용 목적은 enum class(열거형 클래스) 사용 목적과 같다.

답은 간단하게 작성되었다. interface앞에 sealed 예약어만 붙이면 된다.

그런데 sealed 예약어를 붙이는 것과 안붙이는 것의 차이는 뭘까 궁금해졌다.

일반 클래스는 그 클래스 자체가 객체 생성이 가능하지만,

sealed 클래스는 기본으로 abstract를 내장하고 있으므로 객체 생성이 불가능하다고 한다.

그러면 추상 클래스로 만들면 되는거 아닌가싶었다.

하지만 sealed 클래스는 생성자가 private로 강제되어 있다.
(추상 클래스는 접근제어자 고정되어있지 않음)

그렇기 때문에 같은 파일 내에서만 sealed 클래스를 상속할 수 있다.

profile
개발하는 다람쥐

0개의 댓글