ݺߣ

ݺߣShare a Scribd company logo
Clean Code
Trở thành một Lập trình viên tốt hơn
Nguyễn Khắc Nhật
| Agile | Scrum | Kanban | Lean | Java | Scala | Typescript | NodeJS | Bobril | Angular
• Giảng viên
• Lập trình viên
• Chuyên gia Agile, Scrum, Kanban
• Đồng tác giả sách “Cẩm nang Scrum”
• Đồng sáng lập Học viện Agile
• Đồng sáng lập CodeGym
Bạn đã bao giờ?
• Đọc lại những dòng code của mình và tự hỏi:
• Đứa nào code vậy? Đoạn này nghĩa là thế nào đây?
• Code chỗ này nhưng lại phát sinh bug ở chỗ kia?
• Càng code thì hệ thống càng chậm?
• Thậm chí đến một lúc nó còn không chạy được
• Đọc mã nguồn của các hệ thống mã nguồn mở và không hiểu ì?
• Phải viết thêm nhiều câu chú thích trong code của mình?
• Bởi vì nếu không thì không ai hiểu chúng đang làm gì
• Cố gắng viết mã nguồn ngắn nhất có thể, bởi vì như thế mới là xịn?
• Mà không biết rằng chúng rất khó hiểu
Bạn có đang?
• Tự hào về những dòng code mà mình viết ra?
• Hay là chỉ muốn giấu diếm chúng, không muốn ai nhìn thấy?
• Cố gắng dành thời gian để trau chuốt những dòng code?
• Hay là code cho chúng chạy được là tốt rồi?
• Viết code một cách bài bản?
• Hay theo chiến thuật code-and-fix?
Những hình ảnh thường thấy
Clean code - Trở thành một lập trình viên tốt hơn
Clean code - Trở thành một lập trình viên tốt hơn
Clean code - Trở thành một lập trình viên tốt hơn
Clean code - Trở thành một lập trình viên tốt hơn
Clean code - Trở thành một lập trình viên tốt hơn
Bạn viết code như thế nào?
Quy trình thường thấy
Ban ầu
Quy trình thường thấy
Hệ thống đẹp
Quy trình thường thấy
Thêm tính năng mới
Quy trình thường thấy
Thêm một tính năng mới
Quy trình thường thấy
Thay đổi một tính năng
Thời gian trôi ܲ…
Kết quả thường thấy
Bạn có thấy quen thuộc không?
Kết quả thường thấy
Làm thế
nào để
code tiếp?
Bạn có thấy quen thuộc không?
Cách làm đúng
Ban ầu
Cách làm đúng
Hệ thống đẹp
Thêm tính năng mới
Cách làm đúng
Dọn dẹp sạch sẽ
Cách làm đúng
Cách làm đúng
Thêm tính năng mới
Cách làm đúng
Dọn dẹp sạch sẽ
Thời gian trôi ܲ…
Kết quả cần có
Kiến trúc sạch
Về năng suất thì sao?
`
Thời gian
Năng suất
`
Code bẩn
Code sạch
Clean Code là ì?
• Clean Code là tiêu chuẩn của code “tốt”
• Code như thế nào thì được coi là tốt?
Grady Booch
Object Oriented Analysis
Dave Thomas
OTI, Eclipse
Michael Feathers
Working effectively with Legacy Code
Ron Jeffries
Extreme Programming Installed
Extreme Programing Adventures in C#
• Đơn giản
• Trực tiếp
• Dễ đọc hiểu
• Có ít phụ thuộc
• Không có code lặp
• Chạy tất cả các bài kiểm thử
• Không làm mờ đi ý định của người viết
• Giống một bài văn hay
• Giống như là được viết ra bởi một người rất có tâm
Clean Code
Smell Code
• Đặt tên vô nghĩa
• Phương thức quá dài
• Lớp quá dài
• Phương thức xử lý quá nhiều việc
• Phương thức có quá nhiều tham số
• Lạm ụng quá nhiều ghi chú (comment) trong mã nguồn
• Mã nguồn bị trùng lặp
• Sử ụng các giá trị magic
Clean Code ở đâu?
Định danh Hàm Ghi chú
Định dạng
Đối tượng & Lớp
Xử lý lỗi Kiểm thử
Kiến trúc
Clean Code thì được ì?
• Cộng tác dễ dàng hơn
• Debug dễ dàng hơn
• Ít rủi ro hơn
• Năng suất hơn
• Đi được đường dài hơn
• Hạnh phúc hơn
Làm sao để có Clean Code?
• Phải nắm tiêu chuẩn
• Phải biết mục đích
• Phải làm việc với tinh thần phục vụ
• Khác với làm cho xong việc
• Phải học các pattern (nhận diện code thối)
• Phải học các dọn dẹp code (refactor)
Một số ví ụ
Đặt tên có ý nghĩa và đọc được (1)
• Không tốt:
• Tốt:
String yyyymmdstr = new SimpleDateFormat("YYYY/MM/DD").format(new Date());
String currentDate = new SimpleDateFormat("YYYY/MM/DD").format(new Date());
Đặt tên có ý nghĩa và đọc được (2)
• Không tốt • Tốt
public List<int[]> getThem() {
List<int[]> list1 = new ArrayList<int[]>();
for (int[] x : theList)
if (x[0] == 4)
list1.add(x);
return list1;
}
public List<int[]> getFlaggedCells() {
List<int[]> flaggedCells = new ArrayList<int[]>();
for (int[] cell : gameBoard)
if (cell[STATUS_VALUE] == FLAGGED)
flaggedCells.add(cell);
return flaggedCells;
}
Đặt tên đồng nhất khi có cùng ý nghĩa
• Không tốt:
• Tốt:
getUserInfo();
getClientData();
getCustomerRecord();
getUser();
Đặt tên để tìm kiếm được
• Không tốt:
• Tốt:
setTimeout(blastOff, 86400000);
public static final int MILLISECONDS_IN_A_DAY = 86400000;
setTimeout(blastOff, MILLISECONDS_IN_A_DAY);
Đặt tên để tự giải thích ý nghĩa
• Không tốt:
• Tốt:
Application application = new Application();
//...
if(application.getStatus() == "paid") {
//...
}
Application application = new Application();
//...
if(application.isPaid()) {
//...
}
Không thêm các ngữ cảnh thừa
• Không tốt: • Tốt:
class Car {
public String carMake = "Honda";
public String carModel = "Accord";
public String carColor = "Blue";
}
void paintCar(Car car) {
car.carColor = "Red";
}
class Car {
public String make = "Honda";
public String model = "Accord";
public String color = "Blue";
}
void paintCar(Car car) {
car.color = "Red";
}
Mỗi hàm chỉ nên làm một việc
• Không tốt: • Tốt:
public void emailClients(List<Client> clients) {
for (Client client : clients) {
Client clientRecord = repository.findOne(client.getId());
if (clientRecord.isActive()){
email(client);
}
}
}
public void emailClients(List<Client> clients) {
for (Client client : clients) {
if (isActiveClient(client)) {
email(client);
}
}
}
private boolean isActiveClient(Client client) {
Client clientRecord = repository.findOne(client.getId());
return clientRecord.isActive();
}
Tên hàm cần có ý nghĩa
• Không tốt: • Tốt:
private void addToDate(Date date, int month){
//..
}
Date date = new Date();
addToDate(date, 1);
private void addMonthToDate(Date date, int month){
//..
}
Date date = new Date();
addMonthToDate(1, date);
DEMO
Bộ các kỹ thuật liên quan
• Clean Code
• Tiêu chuẩn chất lượng
• Code Refactoring
• Cách để có được Clean Code
• Automation Test
• Đảm bảo an toàn khi refactor
• Design Pattern
• Tiêu chuẩn chất lượng cao hơn
Tham gia các cộng đồng
Coding Dojo
Coderetreat
Clean code - Trở thành một lập trình viên tốt hơn
Ad

Recommended

SOLID - Những nguyên lí sống còn
SOLID - Những nguyên lí sống còn
Nhật Nguyễn Khắc
Quy tắc thiết kế giao diện và viết code C#
Quy tắc thiết kế giao diện và viết code C#
An Nguyen
Giáo trình Tester Full
Giáo trình Tester Full
Thanh Sơn
Bai tap thuc hanh
Bai tap thuc hanh
Lanh Dankhao
Giáo Trình Phương Pháp Luận Lập Trình ICTU
Giáo Trình Phương Pháp Luận Lập Trình ICTU
Ngô Doãn Tình
Bài giảng ngôn ngữ lập trình C cơ bản trường đại học công nghiệp thực phẩm TP...
Bài giảng ngôn ngữ lập trình C cơ bản trường đại học công nghiệp thực phẩm TP...
Thanh Giảng Lê
[Cntt] bài giảng lập trình java bkhcm
[Cntt] bài giảng lập trình java bkhcm
Hong Phuoc Nguyen
Bài giảng công nghệ phần mềm PTIT
Bài giảng công nghệ phần mềm PTIT
NguynMinh294
Code Refactoring: Thay đổi nhỏ - Lợi ích lớn
Code Refactoring: Thay đổi nhỏ - Lợi ích lớn
Nhật Nguyễn Khắc
Seminar clean code
Seminar clean code
Nguyen Thieu
Design Pattern - Những công thức vàng trong thiết kế
Design Pattern - Những công thức vàng trong thiết kế
Nhật Nguyễn Khắc
TÌM HIỂU CÁC KỸ THUẬT KIỂM THỬ PHẦN MỀM
TÌM HIỂU CÁC KỸ THUẬT KIỂM THỬ PHẦN MỀM
Nguyễn Anh
Nhập môn BDD
Nhập môn BDD
Ngoc Dao
Design Pattern qua ví ụ thực tế
Design Pattern qua ví ụ thực tế
VKhang Yang
Đồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềm
Nguyễn Anh
[Seminar] Hướng dẫn viết test case
[Seminar] Hướng dẫn viết test case
Le Vu Trung Thanh
Clean Code
Clean Code
Victor Rentea
Kiem thu phan mem
Kiem thu phan mem
TIen Le
Chương 4. Chuẩn hóa cơ sở dữ liệu
Chương 4. Chuẩn hóa cơ sở dữ liệu
Hoa Le
Bdd
Bdd
HoangThiHien1
KẾ HOẠCH PHÁT TRIỂN BẢN THÂN TRONG 2 NĂM 4 THÁNG TẠI FPT POLYTECHNIC -- VÕ TH...
KẾ HOẠCH PHÁT TRIỂN BẢN THÂN TRONG 2 NĂM 4 THÁNG TẠI FPT POLYTECHNIC -- VÕ TH...
Tài Võ
BÀI 2: Thiết kế FORM và xử lý sự kiện - Giáo trình FPT
BÀI 2: Thiết kế FORM và xử lý sự kiện - Giáo trình FPT
MasterCode.vn
Phần 1: Các khái niệm cơ bản về lập trình
Phần 1: Các khái niệm cơ bản về lập trình
Huy Rùa
Phan tich hệ thống thông tin bằng uml
Phan tich hệ thống thông tin bằng uml
dlmonline24h
Automation Testing & TDD
Automation Testing & TDD
Nhật Nguyễn Khắc
Clean code coding like a professional
Clean code coding like a professional
Nhật Nguyễn Khắc
Clean code
Clean code
ifnu bima
Giáo trình Phân tích và thiết kế giải thuật - CHAP 1
Giáo trình Phân tích và thiết kế giải thuật - CHAP 1
Nguyễn Công Hoàng
Clean code
Clean code
Nam Vo
Clean code
Clean code
Đàm Đàm

More Related Content

What's hot (20)

Code Refactoring: Thay đổi nhỏ - Lợi ích lớn
Code Refactoring: Thay đổi nhỏ - Lợi ích lớn
Nhật Nguyễn Khắc
Seminar clean code
Seminar clean code
Nguyen Thieu
Design Pattern - Những công thức vàng trong thiết kế
Design Pattern - Những công thức vàng trong thiết kế
Nhật Nguyễn Khắc
TÌM HIỂU CÁC KỸ THUẬT KIỂM THỬ PHẦN MỀM
TÌM HIỂU CÁC KỸ THUẬT KIỂM THỬ PHẦN MỀM
Nguyễn Anh
Nhập môn BDD
Nhập môn BDD
Ngoc Dao
Design Pattern qua ví ụ thực tế
Design Pattern qua ví ụ thực tế
VKhang Yang
Đồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềm
Nguyễn Anh
[Seminar] Hướng dẫn viết test case
[Seminar] Hướng dẫn viết test case
Le Vu Trung Thanh
Clean Code
Clean Code
Victor Rentea
Kiem thu phan mem
Kiem thu phan mem
TIen Le
Chương 4. Chuẩn hóa cơ sở dữ liệu
Chương 4. Chuẩn hóa cơ sở dữ liệu
Hoa Le
Bdd
Bdd
HoangThiHien1
KẾ HOẠCH PHÁT TRIỂN BẢN THÂN TRONG 2 NĂM 4 THÁNG TẠI FPT POLYTECHNIC -- VÕ TH...
KẾ HOẠCH PHÁT TRIỂN BẢN THÂN TRONG 2 NĂM 4 THÁNG TẠI FPT POLYTECHNIC -- VÕ TH...
Tài Võ
BÀI 2: Thiết kế FORM và xử lý sự kiện - Giáo trình FPT
BÀI 2: Thiết kế FORM và xử lý sự kiện - Giáo trình FPT
MasterCode.vn
Phần 1: Các khái niệm cơ bản về lập trình
Phần 1: Các khái niệm cơ bản về lập trình
Huy Rùa
Phan tich hệ thống thông tin bằng uml
Phan tich hệ thống thông tin bằng uml
dlmonline24h
Automation Testing & TDD
Automation Testing & TDD
Nhật Nguyễn Khắc
Clean code coding like a professional
Clean code coding like a professional
Nhật Nguyễn Khắc
Clean code
Clean code
ifnu bima
Giáo trình Phân tích và thiết kế giải thuật - CHAP 1
Giáo trình Phân tích và thiết kế giải thuật - CHAP 1
Nguyễn Công Hoàng
Code Refactoring: Thay đổi nhỏ - Lợi ích lớn
Code Refactoring: Thay đổi nhỏ - Lợi ích lớn
Nhật Nguyễn Khắc
Design Pattern - Những công thức vàng trong thiết kế
Design Pattern - Những công thức vàng trong thiết kế
Nhật Nguyễn Khắc
TÌM HIỂU CÁC KỸ THUẬT KIỂM THỬ PHẦN MỀM
TÌM HIỂU CÁC KỸ THUẬT KIỂM THỬ PHẦN MỀM
Nguyễn Anh
Design Pattern qua ví ụ thực tế
Design Pattern qua ví ụ thực tế
VKhang Yang
Đồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềm
Nguyễn Anh
[Seminar] Hướng dẫn viết test case
[Seminar] Hướng dẫn viết test case
Le Vu Trung Thanh
Kiem thu phan mem
Kiem thu phan mem
TIen Le
Chương 4. Chuẩn hóa cơ sở dữ liệu
Chương 4. Chuẩn hóa cơ sở dữ liệu
Hoa Le
KẾ HOẠCH PHÁT TRIỂN BẢN THÂN TRONG 2 NĂM 4 THÁNG TẠI FPT POLYTECHNIC -- VÕ TH...
KẾ HOẠCH PHÁT TRIỂN BẢN THÂN TRONG 2 NĂM 4 THÁNG TẠI FPT POLYTECHNIC -- VÕ TH...
Tài Võ
BÀI 2: Thiết kế FORM và xử lý sự kiện - Giáo trình FPT
BÀI 2: Thiết kế FORM và xử lý sự kiện - Giáo trình FPT
MasterCode.vn
Phần 1: Các khái niệm cơ bản về lập trình
Phần 1: Các khái niệm cơ bản về lập trình
Huy Rùa
Phan tich hệ thống thông tin bằng uml
Phan tich hệ thống thông tin bằng uml
dlmonline24h
Giáo trình Phân tích và thiết kế giải thuật - CHAP 1
Giáo trình Phân tích và thiết kế giải thuật - CHAP 1
Nguyễn Công Hoàng

Similar to Clean code - Trở thành một lập trình viên tốt hơn (20)

Clean code
Clean code
Nam Vo
Clean code
Clean code
Đàm Đàm
How to write good code
How to write good code
Minh Hoang
Programming
Programming
Nguyên Thành Võ
Ngân hàng đảm bảo chất lượng phần mềm PTIT - Chuẩn SQA
Ngân hàng đảm bảo chất lượng phần mềm PTIT - Chuẩn SQA
Popping Khiem - Funky Dance Crew PTIT
The art of readable code - Chapter I,II
The art of readable code - Chapter I,II
Trần Hiếu
Phong cach lap trinh c++
Phong cach lap trinh c++
ptquang160492
Phong cach lap trinh c++
Phong cach lap trinh c++
Informatics and Maths
Code convention
Code convention
hanoiaptech
Code convention
Code convention
hanoiaptech
Lap-trinh-hieu-qua-Cac-khia-canh-quan-trong
Lap-trinh-hieu-qua-Cac-khia-canh-quan-trong
doannhathao15122004
Vb6 16 (10)
Vb6 16 (10)
Học Huỳnh Bá
Coding Standard (Chuẩn Mã Nguồn)
Coding Standard (Chuẩn Mã Nguồn)
Hong Le Van
Chuanmanguon 151124092923-lva1-app6892
Chuanmanguon 151124092923-lva1-app6892
HaiNguyen870
Coding standard
Coding standard
Nguyen Van Phuc
Lập trình tinh giản
Lập trình tinh giản
Dieu Le Hoang
Oop 0
Oop 0
Thai Hoc Vu
Tortoise svn huong dan
Tortoise svn huong dan
whitehorse4IT
Seminar apply OOP in maintain software
Seminar apply OOP in maintain software
VKhang Yang
5 implementation
5 implementation
Tho Da
Ad

More from Nhật Nguyễn Khắc (7)

Reflective Learning
Reflective Learning
Nhật Nguyễn Khắc
Livestream - Nhật ký học lập trình
Livestream - Nhật ký học lập trình
Nhật Nguyễn Khắc
Livestream - Học lập trình là học ì?
Livestream - Học lập trình là học ì?
Nhật Nguyễn Khắc
Hội thảo nghề nghiệp tại CodeGym 6/6/2020
Hội thảo nghề nghiệp tại CodeGym 6/6/2020
Nhật Nguyễn Khắc
WHY DO WE REPORT?
WHY DO WE REPORT?
Nhật Nguyễn Khắc
Live stream: Học lập trình
Live stream: Học lập trình
Nhật Nguyễn Khắc
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
Nhật Nguyễn Khắc
Ad

Clean code - Trở thành một lập trình viên tốt hơn

  • 1. Clean Code Trở thành một Lập trình viên tốt hơn Nguyễn Khắc Nhật
  • 2. | Agile | Scrum | Kanban | Lean | Java | Scala | Typescript | NodeJS | Bobril | Angular • Giảng viên • Lập trình viên • Chuyên gia Agile, Scrum, Kanban • Đồng tác giả sách “Cẩm nang Scrum” • Đồng sáng lập Học viện Agile • Đồng sáng lập CodeGym
  • 3. Bạn đã bao giờ? • Đọc lại những dòng code của mình và tự hỏi: • Đứa nào code vậy? Đoạn này nghĩa là thế nào đây? • Code chỗ này nhưng lại phát sinh bug ở chỗ kia? • Càng code thì hệ thống càng chậm? • Thậm chí đến một lúc nó còn không chạy được • Đọc mã nguồn của các hệ thống mã nguồn mở và không hiểu ì? • Phải viết thêm nhiều câu chú thích trong code của mình? • Bởi vì nếu không thì không ai hiểu chúng đang làm gì • Cố gắng viết mã nguồn ngắn nhất có thể, bởi vì như thế mới là xịn? • Mà không biết rằng chúng rất khó hiểu
  • 4. Bạn có đang? • Tự hào về những dòng code mà mình viết ra? • Hay là chỉ muốn giấu diếm chúng, không muốn ai nhìn thấy? • Cố gắng dành thời gian để trau chuốt những dòng code? • Hay là code cho chúng chạy được là tốt rồi? • Viết code một cách bài bản? • Hay theo chiến thuật code-and-fix?
  • 5. Những hình ảnh thường thấy
  • 11. Bạn viết code như thế nào?
  • 12. Quy trình thường thấy Ban ầu
  • 13. Quy trình thường thấy Hệ thống đẹp
  • 14. Quy trình thường thấy Thêm tính năng mới
  • 15. Quy trình thường thấy Thêm một tính năng mới
  • 16. Quy trình thường thấy Thay đổi một tính năng
  • 18. Kết quả thường thấy Bạn có thấy quen thuộc không?
  • 19. Kết quả thường thấy Làm thế nào để code tiếp? Bạn có thấy quen thuộc không?
  • 21. Cách làm đúng Hệ thống đẹp
  • 22. Thêm tính năng mới Cách làm đúng
  • 23. Dọn dẹp sạch sẽ Cách làm đúng
  • 24. Cách làm đúng Thêm tính năng mới
  • 25. Cách làm đúng Dọn dẹp sạch sẽ
  • 27. Kết quả cần có Kiến trúc sạch
  • 28. Về năng suất thì sao? ` Thời gian Năng suất ` Code bẩn Code sạch
  • 30. • Clean Code là tiêu chuẩn của code “tốt” • Code như thế nào thì được coi là tốt?
  • 31. Grady Booch Object Oriented Analysis Dave Thomas OTI, Eclipse Michael Feathers Working effectively with Legacy Code Ron Jeffries Extreme Programming Installed Extreme Programing Adventures in C#
  • 32. • Đơn giản • Trực tiếp • Dễ đọc hiểu • Có ít phụ thuộc • Không có code lặp • Chạy tất cả các bài kiểm thử • Không làm mờ đi ý định của người viết • Giống một bài văn hay • Giống như là được viết ra bởi một người rất có tâm Clean Code
  • 33. Smell Code • Đặt tên vô nghĩa • Phương thức quá dài • Lớp quá dài • Phương thức xử lý quá nhiều việc • Phương thức có quá nhiều tham số • Lạm ụng quá nhiều ghi chú (comment) trong mã nguồn • Mã nguồn bị trùng lặp • Sử ụng các giá trị magic
  • 34. Clean Code ở đâu? Định danh Hàm Ghi chú Định dạng Đối tượng & Lớp Xử lý lỗi Kiểm thử Kiến trúc
  • 35. Clean Code thì được ì? • Cộng tác dễ dàng hơn • Debug dễ dàng hơn • Ít rủi ro hơn • Năng suất hơn • Đi được đường dài hơn • Hạnh phúc hơn
  • 36. Làm sao để có Clean Code? • Phải nắm tiêu chuẩn • Phải biết mục đích • Phải làm việc với tinh thần phục vụ • Khác với làm cho xong việc • Phải học các pattern (nhận diện code thối) • Phải học các dọn dẹp code (refactor)
  • 38. Đặt tên có ý nghĩa và đọc được (1) • Không tốt: • Tốt: String yyyymmdstr = new SimpleDateFormat("YYYY/MM/DD").format(new Date()); String currentDate = new SimpleDateFormat("YYYY/MM/DD").format(new Date());
  • 39. Đặt tên có ý nghĩa và đọc được (2) • Không tốt • Tốt public List<int[]> getThem() { List<int[]> list1 = new ArrayList<int[]>(); for (int[] x : theList) if (x[0] == 4) list1.add(x); return list1; } public List<int[]> getFlaggedCells() { List<int[]> flaggedCells = new ArrayList<int[]>(); for (int[] cell : gameBoard) if (cell[STATUS_VALUE] == FLAGGED) flaggedCells.add(cell); return flaggedCells; }
  • 40. Đặt tên đồng nhất khi có cùng ý nghĩa • Không tốt: • Tốt: getUserInfo(); getClientData(); getCustomerRecord(); getUser();
  • 41. Đặt tên để tìm kiếm được • Không tốt: • Tốt: setTimeout(blastOff, 86400000); public static final int MILLISECONDS_IN_A_DAY = 86400000; setTimeout(blastOff, MILLISECONDS_IN_A_DAY);
  • 42. Đặt tên để tự giải thích ý nghĩa • Không tốt: • Tốt: Application application = new Application(); //... if(application.getStatus() == "paid") { //... } Application application = new Application(); //... if(application.isPaid()) { //... }
  • 43. Không thêm các ngữ cảnh thừa • Không tốt: • Tốt: class Car { public String carMake = "Honda"; public String carModel = "Accord"; public String carColor = "Blue"; } void paintCar(Car car) { car.carColor = "Red"; } class Car { public String make = "Honda"; public String model = "Accord"; public String color = "Blue"; } void paintCar(Car car) { car.color = "Red"; }
  • 44. Mỗi hàm chỉ nên làm một việc • Không tốt: • Tốt: public void emailClients(List<Client> clients) { for (Client client : clients) { Client clientRecord = repository.findOne(client.getId()); if (clientRecord.isActive()){ email(client); } } } public void emailClients(List<Client> clients) { for (Client client : clients) { if (isActiveClient(client)) { email(client); } } } private boolean isActiveClient(Client client) { Client clientRecord = repository.findOne(client.getId()); return clientRecord.isActive(); }
  • 45. Tên hàm cần có ý nghĩa • Không tốt: • Tốt: private void addToDate(Date date, int month){ //.. } Date date = new Date(); addToDate(date, 1); private void addMonthToDate(Date date, int month){ //.. } Date date = new Date(); addMonthToDate(1, date);
  • 46. DEMO
  • 47. Bộ các kỹ thuật liên quan • Clean Code • Tiêu chuẩn chất lượng • Code Refactoring • Cách để có được Clean Code • Automation Test • Đảm bảo an toàn khi refactor • Design Pattern • Tiêu chuẩn chất lượng cao hơn
  • 48. Tham gia các cộng đồng