SlideShare a Scribd company logo
1 of 51
Download to read offline
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 gì?
• 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
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 qua…
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 qua…
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à gì?
• 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 dụng quá nhiều ghi chú (comment) trong mã nguồn
• Mã nguồn bị trùng lặp
• Sử dụ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 gì?
• 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í dụ
Đặ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

More Related Content

What's hot

Bài giảng cơ sở dữ liệu
Bài giảng cơ sở dữ liệuBài giảng cơ sở dữ liệu
Bài giảng cơ sở dữ liệutrieulongweb
 
Design Pattern qua ví dụ thực tế
Design Pattern qua ví dụ thực tếDesign Pattern qua ví dụ thực tế
Design Pattern qua ví dụ thực tếVKhang Yang
 
[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github
[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github
[Đồ án môn học] - Đề tài: Tìm hiểu Git và GithubMatt Colonel
 
Ebook hướng dẫn lập trình từ điển
Ebook hướng dẫn lập trình từ điểnEbook hướng dẫn lập trình từ điển
Ebook hướng dẫn lập trình từ điểnAnh Pham Duy
 
Ky nang quan ly thoi gian
Ky nang quan ly thoi gianKy nang quan ly thoi gian
Ky nang quan ly thoi gianThao Media 99
 
Bài giảng Kỹ năng Tư duy sáng tạo & hiệu quả
Bài giảng Kỹ năng Tư duy sáng tạo & hiệu quảBài giảng Kỹ năng Tư duy sáng tạo & hiệu quả
Bài giảng Kỹ năng Tư duy sáng tạo & hiệu quảTâm Việt Group
 
Tổng quan về cơ sở dữ liệu
Tổng quan về cơ sở dữ liệuTổng quan về cơ sở dữ liệu
Tổng quan về cơ sở dữ liệuTonhaco Bestco
 
HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )
HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )
HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )nataliej4
 
Slide đồ án tốt nghiệp
Slide đồ án tốt nghiệpSlide đồ án tốt nghiệp
Slide đồ án tốt nghiệpToan Pham
 
Đồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềmĐồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềmNguyễn Anh
 
Giáo trình xử lý ảnh
Giáo trình xử lý ảnhGiáo trình xử lý ảnh
Giáo trình xử lý ảnhTùng Trần
 
Quy chuẩn làm powerpoint
Quy chuẩn làm powerpointQuy chuẩn làm powerpoint
Quy chuẩn làm powerpointNguyễn Thân
 
Nhập môn công nghệ phần mềm
Nhập môn công nghệ phần mềmNhập môn công nghệ phần mềm
Nhập môn công nghệ phần mềmTrần Gia Bảo
 

What's hot (20)

Bài giảng cơ sở dữ liệu
Bài giảng cơ sở dữ liệuBài giảng cơ sở dữ liệu
Bài giảng cơ sở dữ liệu
 
Design Pattern qua ví dụ thực tế
Design Pattern qua ví dụ thực tếDesign Pattern qua ví dụ thực tế
Design Pattern qua ví dụ thực tế
 
[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github
[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github
[Đồ án môn học] - Đề tài: Tìm hiểu Git và Github
 
Ebook hướng dẫn lập trình từ điển
Ebook hướng dẫn lập trình từ điểnEbook hướng dẫn lập trình từ điển
Ebook hướng dẫn lập trình từ điển
 
Đề tài: Nghiên cứu thuật toán K-nearest neighbor, HAY, 9đ
Đề tài: Nghiên cứu thuật toán K-nearest neighbor, HAY, 9đĐề tài: Nghiên cứu thuật toán K-nearest neighbor, HAY, 9đ
Đề tài: Nghiên cứu thuật toán K-nearest neighbor, HAY, 9đ
 
Lý Thuyết SQL
Lý Thuyết SQLLý Thuyết SQL
Lý Thuyết SQL
 
Ky nang quan ly thoi gian
Ky nang quan ly thoi gianKy nang quan ly thoi gian
Ky nang quan ly thoi gian
 
CSDLP3.ppt
CSDLP3.pptCSDLP3.ppt
CSDLP3.ppt
 
Đề tài: Xây dựng website giới thiệu sản phẩm phần mềm, HOT
Đề tài: Xây dựng website giới thiệu sản phẩm phần mềm, HOTĐề tài: Xây dựng website giới thiệu sản phẩm phần mềm, HOT
Đề tài: Xây dựng website giới thiệu sản phẩm phần mềm, HOT
 
Bài giảng Kỹ năng Tư duy sáng tạo & hiệu quả
Bài giảng Kỹ năng Tư duy sáng tạo & hiệu quảBài giảng Kỹ năng Tư duy sáng tạo & hiệu quả
Bài giảng Kỹ năng Tư duy sáng tạo & hiệu quả
 
Tổng quan về cơ sở dữ liệu
Tổng quan về cơ sở dữ liệuTổng quan về cơ sở dữ liệu
Tổng quan về cơ sở dữ liệu
 
HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )
HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )
HỆ THỐNG QUẢN lý NHÂN sự ỨNG DỤNG CÔNG NGHỆ RFID (full + )
 
Slide đồ án tốt nghiệp
Slide đồ án tốt nghiệpSlide đồ án tốt nghiệp
Slide đồ án tốt nghiệp
 
Báo cáo Quản lý dự án phần mềm PTIT
Báo cáo Quản lý dự án phần mềm PTITBáo cáo Quản lý dự án phần mềm PTIT
Báo cáo Quản lý dự án phần mềm PTIT
 
Đề tài: Xây dựng Website quản lý điểm trường Phổ thông, 9đ
Đề tài: Xây dựng Website quản lý điểm trường Phổ thông, 9đĐề tài: Xây dựng Website quản lý điểm trường Phổ thông, 9đ
Đề tài: Xây dựng Website quản lý điểm trường Phổ thông, 9đ
 
Đồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềmĐồ án kiểm thử phần mềm
Đồ án kiểm thử phần mềm
 
Giáo trình xử lý ảnh
Giáo trình xử lý ảnhGiáo trình xử lý ảnh
Giáo trình xử lý ảnh
 
Quy chuẩn làm powerpoint
Quy chuẩn làm powerpointQuy chuẩn làm powerpoint
Quy chuẩn làm powerpoint
 
Nhập môn công nghệ phần mềm
Nhập môn công nghệ phần mềmNhập môn công nghệ phần mềm
Nhập môn công nghệ phần mềm
 
Bài giảng Mạng máy tính
Bài giảng Mạng máy tínhBài giảng Mạng máy tính
Bài giảng Mạng máy tính
 

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

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ế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
 
Livestream - Học lập trình là học gì?
Livestream - Học lập trình là học gì?Livestream - Học lập trình là học gì?
Livestream - Học lập trình là học gì?Nhật Nguyễn Khắc
 
How to write good code
How to write good code How to write good code
How to write good code Minh Hoang
 
An Introduction to get a Job in Tech Industry in Japan
An Introduction to get a Job in Tech Industry in JapanAn Introduction to get a Job in Tech Industry in Japan
An Introduction to get a Job in Tech Industry in JapanTrung Vu
 
Hành trình trở thành web đì ve lốp pơ
Hành trình trở thành web đì ve lốp pơHành trình trở thành web đì ve lốp pơ
Hành trình trở thành web đì ve lốp pơHuy Hoàng Phạm
 
Itlc2015
Itlc2015Itlc2015
Itlc2015Huy Do
 
Seminar apply OOP in maintain software
Seminar apply OOP in maintain softwareSeminar apply OOP in maintain software
Seminar apply OOP in maintain softwareVKhang Yang
 
[Cntt] bài giảng java khtn hcm
[Cntt] bài giảng java   khtn hcm[Cntt] bài giảng java   khtn hcm
[Cntt] bài giảng java khtn hcmHong Phuoc Nguyen
 
Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?
Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?
Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?ITguru.vn
 
Chuanmanguon 151124092923-lva1-app6892
Chuanmanguon 151124092923-lva1-app6892Chuanmanguon 151124092923-lva1-app6892
Chuanmanguon 151124092923-lva1-app6892HaiNguyen870
 
Coding Standard (Chuẩn Mã Nguồn)
Coding Standard (Chuẩn Mã Nguồn)Coding Standard (Chuẩn Mã Nguồn)
Coding Standard (Chuẩn Mã Nguồn)Hong Le Van
 
Câu hỏi phỏng vấn.pdf
Câu hỏi phỏng vấn.pdfCâu hỏi phỏng vấn.pdf
Câu hỏi phỏng vấn.pdfGrowup Work
 
Seminar clean code
Seminar clean codeSeminar clean code
Seminar clean codeNguyen Thieu
 
Ngon ngu lap_trinh_c++
Ngon ngu lap_trinh_c++Ngon ngu lap_trinh_c++
Ngon ngu lap_trinh_c++Da To
 

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

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ế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ế
 
Livestream - Học lập trình là học gì?
Livestream - Học lập trình là học gì?Livestream - Học lập trình là học gì?
Livestream - Học lập trình là học gì?
 
How to write good code
How to write good code How to write good code
How to write good code
 
An Introduction to get a Job in Tech Industry in Japan
An Introduction to get a Job in Tech Industry in JapanAn Introduction to get a Job in Tech Industry in Japan
An Introduction to get a Job in Tech Industry in Japan
 
Hành trình trở thành web đì ve lốp pơ
Hành trình trở thành web đì ve lốp pơHành trình trở thành web đì ve lốp pơ
Hành trình trở thành web đì ve lốp pơ
 
Itlc2015
Itlc2015Itlc2015
Itlc2015
 
Automation Testing & TDD
Automation Testing & TDDAutomation Testing & TDD
Automation Testing & TDD
 
Tdd in action
Tdd in actionTdd in action
Tdd in action
 
Slide offline SEO Hà Nội Cùng ThuyCuong
Slide offline SEO Hà Nội Cùng ThuyCuongSlide offline SEO Hà Nội Cùng ThuyCuong
Slide offline SEO Hà Nội Cùng ThuyCuong
 
Seminar apply OOP in maintain software
Seminar apply OOP in maintain softwareSeminar apply OOP in maintain software
Seminar apply OOP in maintain software
 
[Cntt] bài giảng java khtn hcm
[Cntt] bài giảng java   khtn hcm[Cntt] bài giảng java   khtn hcm
[Cntt] bài giảng java khtn hcm
 
Pbc day-01-introduction
Pbc day-01-introductionPbc day-01-introduction
Pbc day-01-introduction
 
Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?
Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?
Bạn cần chuẩn bị gì khi đi phỏng vấn vị trí DevOps?
 
Chuanmanguon 151124092923-lva1-app6892
Chuanmanguon 151124092923-lva1-app6892Chuanmanguon 151124092923-lva1-app6892
Chuanmanguon 151124092923-lva1-app6892
 
Coding Standard (Chuẩn Mã Nguồn)
Coding Standard (Chuẩn Mã Nguồn)Coding Standard (Chuẩn Mã Nguồn)
Coding Standard (Chuẩn Mã Nguồn)
 
Code convention
Code conventionCode convention
Code convention
 
Câu hỏi phỏng vấn.pdf
Câu hỏi phỏng vấn.pdfCâu hỏi phỏng vấn.pdf
Câu hỏi phỏng vấn.pdf
 
Seminar clean code
Seminar clean codeSeminar clean code
Seminar clean code
 
Introduction to coding dojo
Introduction to coding dojoIntroduction to coding dojo
Introduction to coding dojo
 
Ngon ngu lap_trinh_c++
Ngon ngu lap_trinh_c++Ngon ngu lap_trinh_c++
Ngon ngu lap_trinh_c++
 

More from 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ìnhLivestream - Nhật ký học lập trình
Livestream - Nhật ký học lập trìnhNhậ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/2020Hội thảo nghề nghiệp tại CodeGym 6/6/2020
Hội thảo nghề nghiệp tại CodeGym 6/6/2020Nhật Nguyễn Khắc
 
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018Nhật Nguyễn Khắc
 

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

Reflective Learning
Reflective LearningReflective Learning
Reflective Learning
 
Livestream - Nhật ký học lập trình
Livestream - Nhật ký học lập trìnhLivestream - Nhật ký học lập trình
Livestream - Nhật ký học lập trình
 
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/2020Hộ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
 
WHY DO WE REPORT?
WHY DO WE REPORT?WHY DO WE REPORT?
WHY DO WE REPORT?
 
Live stream: Học lập trình
Live stream: Học lập trìnhLive stream: Học lập trình
Live stream: Học lập trình
 
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
Agile Education - Classroms need Agility - Agile Vietnam Conference 2018
 
Clean code coding like a professional
Clean code   coding like a professionalClean code   coding like a professional
Clean code coding like a professional
 

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 gì? • 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
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 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 dụng quá nhiều ghi chú (comment) trong mã nguồn • Mã nguồn bị trùng lặp • Sử dụ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 gì? • 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