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

Fine-grain refactoring deep dive (8) - Boolean parameter.

0 0 19

Người đăng: logbasex

Theo Viblo Asia

1. Issue

Giả sử bạn có một phương thức để setup một chiếc xe đạp Fixed Gear như sau:

image.png

void buildBike() { setPedal(); setRim(); ...
}

Mọi thứ không có gì thay đổi cho đến một ngày đẹp trời công ty bạn thay đổi chiến lược kinh doanh và bắt đầu cho phép khách hàng đặt mua xe Fixed Gear với phanh được lắp sẵn. Nhận được thông tin đó, bạn quyết định mở rộng phương thức buildBike() bằng cách thêm tham số boolean includeBrakes để xác định hành vi của nó:

void buildBike(boolean includeBrakes) { if (includeBrakes) { // do something } ...
}

Đoạn code trên thoạt nhìn khá ổn, tuy nhiên vấn đề đã bắt đầu manh nha xuất hiện ở đây. Sẽ ra sao nếu công ty lại thay đổi chiến lược sản xuất những chiếc xe đẹp với những phụ kiện khác nhau đi kèm như bộ đề, đèn trước/sau, khung...?

Chả sao cả 😆😆😆, bạn nói. Nếu vấn đề không được giải quyết bằng một tham số boolean thì có nghĩa rằng chúng ta cần nhiều biến boolean hơn.

void buildBike(boolean includeBrakes, boolean includeGear, boolean inculdeLight, boolean includeFrame) { if (includeBrakes) { // do something } if (includeGear) { // do something } if (includeLight) { // do something } if (includeFrame) { // do something } ...
}

Và nếu khách hàng cần một chiếc xe đạp với chỉ duy nhất một phụ kiện là bộ phanh lắp sẵn thì bạn sẽ gọi phương thức buildBike() như thế này:

buildBike(true, false, false, false);

Đến đây mọi thứ đã sáng tỏ. Chúng ta dễ dàng nhận ra những vấn đề sau:

  • Khó đọc và rối mắt (low sematic), không những trong phương thức mà cả khi gọi phương thức (Vi phạm SOLID). Với một số ngôn ngữ như Python thì khi nhìn qua biết tham số nào được gán là true hay false còn đỡ, nhưng đối với Java thì thật là không thể xác định được nếu bạn không nhớ tên và thứ tự các tham số truyền vào.
  • Khó để tìm kiếm, method hierachy từ method này trở nên rất nhiều, bạn sẽ mất kha khá thời gian để xác định chỗ nào thì cái xe đạp có phanh, chỗ nào thì cái xe đạp có đèn...
  • Khả năng độ phức tạp của phương thức sẽ tăng lên theo thời gian.

If your function has 17 parameters, you are missing one.

2. Solution

Tuân thủ theo Single Responsibility PrincipleOpen-Closed Principle thì chúng ta sẽ viết lại đoạn code trên bằng cách tách ra nhiều phương thức nhỏ thực hiện tính năng độc lập.

buildBikeWithBrakes() {
...
} buildBikeWithBrakesAndGear() {
...
} ...

Nếu có nhiều hơn 4 hay 5 options thì việc viết method sẽ quá dài, lúc đó việc cân nhắc chuyển sang dùng builder pattern cũng là một lựa chọn tốt. Bạn có thể sử dụng enum như một lựa chọn thay thế, nhưng đối với mình thì việc tách method vẫn dễ đọc và rõ ràng hơn.

References

Bình luận

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

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

Tổng hợp các bài hướng dẫn về Design Pattern - 23 mẫu cơ bản của GoF

Link bài viết gốc: https://gpcoder.com/4164-gioi-thieu-design-patterns/. Design Patterns là gì. Design Patterns không phải là ngôn ngữ cụ thể nào cả.

0 0 277

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

Học Spring Boot bắt đầu từ đâu?

1. Giới thiệu Spring Boot. 1.1.

0 0 257

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

Cần chuẩn bị gì để bắt đầu học Java

Cần chuẩn bị những gì để bắt đầu lập trình Java. 1.1. Cài JDK hay JRE.

0 0 37

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

Sử dụng ModelMapper trong Spring Boot

Bài hôm nay sẽ là cách sử dụng thư viện ModelMapper để mapping qua lại giữa các object trong Spring nhé. Trang chủ của ModelMapper đây http://modelmapper.org/, đọc rất dễ hiểu dành cho các bạn muốn tìm hiểu sâu hơn. 1.

0 0 180

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

[Java] 1 vài tip nhỏ khi sử dụng String hoặc Collection part 1

. Hello các bạn, hôm nay mình sẽ chia sẻ về mẹo check String null hay full space một cách tiện lợi. Mình sẽ sử dụng thư viện Lớp StringUtils download file jar để import vào thư viện tại (link).

0 0 55

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

Deep Learning với Java - Tại sao không?

Muốn tìm hiểu về Machine Learning / Deep Learning nhưng với background là Java thì sẽ như thế nào và bắt đầu từ đâu? Để tìm được câu trả lời, hãy đọc bài viết này - có thể kỹ năng Java vốn có sẽ giúp bạn có những chuyến phiêu lưu thú vị. DJL là tên viết tắt của Deep Java Library - một thư viện mã ng

0 0 124