예제로 사용할 클래스
data class Person (val name : String, var age : Int)
run : with이랑 비슷한 역할로,
이미 생성된 Context Object 객체를 사용할 때 호출하며, with와는 전달받는 위치가 다릅니다.
그리고 가장 중요한 차이점은 앞에 Safe Call (?.)을 붙여서 null 체크까지 할 수 있기 때문에,
with보다는 run이 더 자주 사용되는 이유 중 하나라고 할 수 있습니다.
val person = Person("홍길동", 30)
// this로 참조
person.run {
println("이름 : ${name}")
println("이름 : ${this.name}")
}
// 결과
이름 : 홍길동
이름 : 홍길동
let : 객체 결과값에 하나 이상의 함수를 호출하는 경우 사용함.
val person = Person("홍길동", 30)
// it으로 참조
person.let {
println("이름 : ${it.name}")
}
// 혹은 전달 인자명을 직접 지정할 수 있음.
person.let { value ->
println("이름 : ${value.name}")
}
// 결과
이름 : 홍길동
이름 : 홍길동
val numbers2 = mutableListOf("one", "two", "three", "four", "five")
numbers2.map { it.length }.filter { it > 3 }.let {
println(it)
// 추가적인 함수 호출 가능
}
// 결과
[5, 4, 4]
with : 이미 생성된 Context Object 객체를 인자로 받아서 사용하는 것이
효율적일 때는 with을 사용함. ( 근데 run을 더 자주 쓸듯)
val numbers = mutableListOf("one", "two", "three")
// 반환 값을 무시하고 바로 람다식을 사용하여, 임시 범위를 만들어서 사용할 수도 있습니다.
with(numbers) {
val firstItem = first()
val lastItem = last()
println("'with' 는 ${this} 로 참조합니다.")
println("${size}개의 요소를 포함합니다.")
println("첫번째 항목: $firstItem, 마지막 항목: $lastItem")
}
// 결과
'with' 는 [one, two, three] 로 참조합니다.
3개의 요소를 포함합니다.
첫번째 항목: one, 마지막 항목: five
apply : 보통 객체 초기화 시에 가장 많이 사용.
val person2 = Person("홍길동", 0).apply {
age = 30
}
also : 기존 객체를 수정하거나 변경하지 않고,
디버깅을 위한 로깅 등의 추가적인 부가 작업을 하려고 할 때 사용합니다.
val numberList = mutableListOf<Double>()
numberList.also { println("Population the list") }
.apply {
add(2.71)
add(3.14)
add(1.0)
}
.also { println("Sorting the list") }
.sort()
// 결과
Population the list
Sorting the list
// 따라서 Context Object를 반환하는 함수의 return문에도 사용 가능.
fun getRandomInt() : Int {
return Random.nextInt(100).also {
println("getRandomInt() generated value $it")
}
}
val i = getRandomInt()
// 결과
getRandomInt() generated value 31