작성
·
358
1
안녕하세요 강의 잘 보고 있습니다
다름이 아니라 7분 12초쯤에 private final List 를 코틀린으로 변환 시키는 작업을 하는데 약간 이해가 안돼는 점이..
final 이라 List는 불변이여서 val을 썼는데 뒤에는 MutableList 가변 리스트로 받아주니까 상충되는 느낌이 드는데... 이부분이 이해가 잘 되지 않습니다!
답변 1
1
안녕하세요! wnsqud70님~!! 😊 아이고~ 좋은 질문이십니다!!
아래 4가지의 차이를 이해하시면 좋습니다!
val list: List<Int> // (1)
var list: List<Int> // (2)
val list: MutableList<Int> // (3)
var list: MutableList<Int> // (4)
먼저 1번과 3번의 공통점은 val을 사용한 불변 변수라는 점입니다!
제가 변수에 강조를 한 이유는 list라는 변수이름에 다른 리스트를 할당할 수 없다는 의미이기 때문에 그렇습니다! 예를 들어서 아래 코드는 불가능합니다!
val list1: List<Int> = listOf(1)
list1 = listOf(2) // 에러 발생
val list2: MutableList<Int> = listOf(1)
list2 = listOf(2) // 에러 발생
반면 2번과 4번은 가변 변수이기 때문에, 원래 있던 list에 다른 리스트를 할당할 수 있습니다.
var list1: List<Int> = listOf(1)
list1 = listOf(2) // 가능!
var list2: MutableList<Int> = listOf(1)
list2 = listOf(2) // 가능!
이것이 val과 var의 차이이죠!
반면 다른 관점으로 4가지 경우를 바라보겠습니다! 가변 컬렉션과 불변 컬렉션입니다.
1번과 2번은 List
를 사용한 불변 컬렉션입니다. 때문에 val이건 var이건 리스트에 새로운 원소를 추가할 수 없죠!
var list1: List<Int> = listOf(1)
list1.add(2) // 에러 발생
var list2: List<Int> = listOf(1)
list2.add(2) // 에러 발생
반면, 3번과 4번은 MutableList
를 사용한 가변 컬렉션입니다. 때문에 val이건 var이건 리스트에 새로운 원소를 추가할 수 있죠!
var list1: MutableList<Int> = listOf(1)
list1.add(2) // 가능!
var list2: MutableList<Int> = listOf(1)
list2.add(2) // 가능!
즉, val + MutableList의 조합이라면 list자체에 다른 리스트를 할당할 수는 없되, 리스트에 새로운 원소는 추가할 수 있는 case가 됩니다 ㅎㅎㅎ
이렇게 생각해보시는게 이해하시는데 도움될 것 같아요!
더 설명이 필요하신 부분 있으시면 편하게 말씀해주세요! 감사합니다!! 🙏