컴퓨터 관련/Kotlin 정보
코틀린 디자인 패턴 - 동작 패턴 이해하기 (책임연쇄)
보뇨
2024. 12. 16. 17:34
반응형
내가 가장 좋아하는 책임연쇄패턴인데 이전 글과 동일하게 작가가 typealias 로 만들었길래 재미있어서 기록해봅니다.
우선 아래 코드는 interface 로 선언했을때 기준입니다.
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
32
33
|
class Chapter04Chain {
@Test
fun sod() {
val chain = BasicValidationHandler(AnswerHandler())
chain.handle(Request("amugae2@naver.com", "question1 -> hello?"))
}
data class Request(val email: String, val question: String)
data class Response(val answer: String)
interface Handler {
fun handle(request: Request): Response
}
class BasicValidationHandler(private val next: Handler) : Handler {
override fun handle(request: Request): Response {
if (request.email.isEmpty()) {
throw IllegalArgumentException()
}
return next.handle(request)
}
}
class AnswerHandler : Handler {
override fun handle(request: Request): Response {
println("validation OK: ${request.email}, ${request.email}")
return Response("validation OK: ${request.email}, ${request.email}")
}
}
}
|
cs |
그리고 여기 코드부터가 typealias 를 사용했을때기준인데
사실 별차이는 없지만 여기서부터 확연히 느껴지는게 Javascript 고차함수와 완전히 동일한거같다는 느낌을 받았다.
그말인즉슨 더 재미있게 짤수있을꺼같은데 다만 동시에 일반 Java 개발자부터 시작하는 분들과 협업할때는 사용하기 어려울꺼같다.
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
|
typealias Handler = (request: Chapter04Chain.Request) -> Chapter04Chain.Response
class Chapter04Chain {
@Test
fun sod() {
val chain = BasicValidationHandler(AnswerHandler())
chain(Request("amugae2@naver.com", "question1 -> hello?"))
}
data class Request(val email: String, val question: String)
data class Response(val answer: String)
class BasicValidationHandler(private val next: Handler) : Handler {
override fun invoke(request: Request): Response {
if (request.email.isEmpty()) {
throw IllegalArgumentException()
}
return next(request)
}
}
class AnswerHandler : Handler {
override fun invoke(request: Request): Response {
println("validation OK: ${request.email}, ${request.email}")
return Response("validation OK: ${request.email}, ${request.email}")
}
}
}
|
cs |
반응형