- vừa được xem lúc

Chia nhỏ Interface sử dụng Kotlin extension và inline functions

0 0 32

Người đăng: Hùng Bá Nguyễn

Theo Viblo Asia

Interface segregation: Nguyên lý thứ 4 trong SOLID

Robert C Martin nổi tiếng với biệt danh “Uncle Bob” đã định nghĩa các nguyên lý SOLID - là những nguyên lý cần tuân theo khi xây dựng phần mềm để dễ mở rộng và dễ bảo trì hơn. SOLID là một từ viết tắt và mỗi chữ cái biểu thị một nguyên lý thiết kế hướng đối tượng. Trong bài viết này, chúng ta sẽ tập trung vào chữ cái “I” (trong SOLID giải thích ý tưởng về chia nhỏ Interface.

Vậy nguyên lý chia nhỏ Interface nói gì:

“Class con không bị buộc phải implement các method mà nó không sử dụng.” Hoặc có thể hiểu: “Thay vì dùng 1 interface lớn, ta nên tách thành nhiều interface nhỏ, với nhiều mục đích cụ thể”

Hãy lấy ví dụ về interface TextWatcher. Interface này được sử dụng rộng rãi trong quá trình phát triển khi chúng ta muốn nhận các event khi người dùng thay đổi chữ/text trong EditText. Ví dụ: Cần hiển thị thông báo Toast nội dung của EditText khi người dùng nhập ký tự vào EditText. Ở đây, chúng ta buộc phải implement cả 3 function của interface TextWatcher. Code sẽ như thế này:

binding.editText.addTextChangedListener(object: TextWatcher { override fun beforeTextChanged(charSequence: CharSequence?, p1: Int, p2: Int, p3: Int) { //NO OP } override fun onTextChanged(charSequence: CharSequence?, p1: Int, p2: Int, p3: Int) { showToast(charSequence.toString()) } override fun afterTextChanged(charSequence: Editable?) { //NO OP } })

Ở đây, chúng ta chỉ cần function onTextChanged để hiển thị Toast. Chúng ta không cần các function beforeTextChangedafterTextChanged và việc implement 2 function này vi phạm nguyên lý chia nhỏ Interface.

Bây giờ câu hỏi đặt ra: Làm thế nào chúng ta có thể chia nhỏ các function trong TextWatcher và chỉ sử dụng function onTextChanged.

Với sự trợ giúp của Extension function trong Kotlin và inline function, chúng ta hãy tối ưu hóa code để tuân theo nguyên lý chia nhỏ interface.

Bắt đầu với việc tạo một Extension function onTextChanged. Việc này sẽ thêm function vào lớp EditText và chúng ta có thể sử dụng nó ở bất cứ đâu chúng ta cần:

inline fun EditText.onTextChange(crossinline listener: (String) -> Unit) { this.addTextChangedListener(object: TextWatcher { override fun beforeTextChanged(charSequence: CharSequence?, p1: Int, p2: Int, p3: Int) { //NO OP } override fun onTextChanged(charSequence: CharSequence?, p1: Int, p2: Int, p3: Int) { listener(charSequence.toString()) } override fun afterTextChanged(p0: Editable?) { //NO OP } })
}

Extension function này được sử dụng như sau:

binding.editText.onTextChange { showToast(it)
}

Chúng ta có thể sử dụng cùng một cách tiếp cận khi chúng ta đang cố gắng triển khai các interface chứa rất nhiều function và chúng ta chỉ cần sử dụng một / hai function trong đó. Sử dụng cách tiếp cận này sẽ làm cho mã ngắn gọn và hiệu quả hơn.

Nguồn: medium

Bình luận

Bài viết tương tự

- vừa được xem lúc

Học Flutter từ cơ bản đến nâng cao. Phần 1: Làm quen cô nàng Flutter

Lời mở đầu. Gần đây, Flutter nổi lên và được Google PR như một xu thế của lập trình di động vậy.

0 0 284

- vừa được xem lúc

Học Flutter từ cơ bản đến nâng cao. Phần 3: Lột trần cô nàng Flutter, BuildContext là gì?

Lời mở đầu. Màn làm quen cô nàng FLutter ở Phần 1 đã gieo rắc vào đầu chúng ta quá nhiều điều bí ẩn về nàng Flutter.

1 1 330

- vừa được xem lúc

[Android] Hiển thị Activity trên màn hình khóa - Show Activity over lock screen

Xin chào các bạn, Hôm nay là 30 tết rồi, ngồi ngắm trời chờ đón giao thừa, trong lúc rảnh rỗi mình quyết định ngồi viết bài sau 1 thời gian vắng bóng. .

0 0 108

- vừa được xem lúc

Tìm hiểu Proguard trong Android

1. Proguard là gì . Cụ thể nó giúp ứng dụng của chúng ta:. .

0 0 102

- vừa được xem lúc

Làm ứng dụng học toán đơn giản với React Native - Phần 6

Chào các bạn một năm mới an khang thịnh vượng, dồi dào sức khỏe. Lại là mình đây Đây là link app mà các bạn đang theo dõi :3 https://play.google.com/store/apps/details?id=com.

0 0 69

- vừa được xem lúc

20 Plugin hữu ích cho Android Studio

1. CodeGlance. Plugin này sẽ nhúng một minimap vào editor cùng với thanh cuộn cũng khá là lớn. Nó sẽ giúp chúng ta xem trước bộ khung của code và cho phép điều hướng đến đoạn code mà ta mong muốn một cách nhanh chóng.

0 0 316