Trang Chủ

Bàn về các nguyên lý lập trình

Nguyên lý lập trình là gì.

Xây dựng và phát triển phầm mềm là một quá trình bao gồm nhiều bước, bắt đầu từ việc viết code, viết test, sau đó fix bug, và rồi là maintain… quá trình này lặp đi lặp lại. Và làm sao để quá trình đó trở nên tốt hơn, tốt hơn từ bắt đầu của việc viết code, người ta bắt đầu nghĩ về các nguyên lý lập trình, và hi vọng rằng khi mọi người tuân thủ theo, mọi thứ sẽ được cải thiện.

Vậy sau khi có các nguyên lý lập trình rồi, việc lập trình của bạn có trở nên cải thiện hơn không, cái đó mình xin để cho các bạn tự trả lời.

Có bao nhiêu nguyên tắc lập trình.

Khi bắt đầu tìm hiểu về các nguyên lý lập trình, một thế giới mở toang ra, và rồi nó khiến bạn không ít lần muốn thôi không tìm hiểu nữa. Quá nhiều nguyên lý. Quá nhiều các lời khuyên. Quá nhiều sự áp đặt rằng chúng ta phải làm thế này, phải làm thế kia.

Có mấy ai thật sự trong chúng ta không Google mà còn nhớ tên các nguyên tắc đó.

Tại sao việc tuân thủ các nguyên tắc lại khó.

Chúng ta dễ dàng tạo ra nguyên tắc cho người khác, chứ không phải nguyên tắc cho bản thân mình. Và con người ta thường có xu lướng phá vỡ các nguyên tắc. Việc tuân theo các nguyên tắc đòi hỏi hiểu biết đúng đắn, duy trì và thiết lập các thói quen, và tất nhiên là nghĩ tới thôi cũng thấy khó rồi.

Sao chúng ta không tạo nguyên tắc cho mình.

Nguyên tắc code sao cho đơn giản (simple)

Khi code lúc nào cũng nghĩ đến việc làm sao cho nó đơn giản nhất có thể. Code đơn giản sẽ có các lợi ích:

Nói thì dễ, nhưng bản thân chương trình máy tính là một thứ vỗn dĩ rất phức tạp, chúng ta ngày hôm nay sỡ dĩ code được đơn giản và dễ dàng là cả một quá trình cải thiện nhiều năm, và sự tiến bộ về phương pháp luận mới ra đời. Hãy tưởng tượng, này xưa code web với các Framework phức tạp thì ngày ngay có Laravel, Reactjs làm cho việc code PHP hay Javascript trở nên dễ dàng hơn rất nhiều. Các phần phức tạp nhất đã được dấu bên trong.

Vậy làm thế nào để code cho đơn giản, cái đó tác giả cũng không biết, nhưng chúng ta có thể tránh đi một điều có dẫn đến code phức tạp.

Nguyên tắc code sao cho gọn gàng, sạch sẽ (clear & clean)

Nói chung thế nào bạn cũng thích những người gọn gàng sạch sẽ, những nơi gọn gàng sạch sẽ, không ai thích code nhìn lộn xộn và nhức đầu. Làm thế nào để có thể code gọn gàng và sạch sẽ:

Và hãy kiên nhẫn để theo đuổi triệt để các nguyên tắc mình đưa ra, hãy nhớ rằng nó không hề đơn giản để làm mọi thứ trở nên gọn gàng và sạch sẽ, phải trải qua nhiều lần cải thiện, rút kinh nghiệm, kiểm điểm bạn mới thiết lập cho mình một bộ các kỹ năng cần thiết để duy trì các thói quen đó.

Nguyên tắc việc code sao cho có thể dễ dàng tái sử dụng (reusable)

Nếu không được reuse các đoạn mã cứ lặp đi lặp lại, mỗi lần sửa chữa, hay thay đổi bạn lại dễ dàng tạo ra bug, bởi vì quên chỗ này chỗ kia, và tất nhiều đọc code rất khó hiểu.

Việc code để tái sử dụng cũng là việc rất khó, vì ban đầu bạn chỉ cố viết để nó work, chứ không phải viết code cho ngày mai, cho thằng khác nó dùng, lo nghĩ cho ngày mai là chuyện hết sức tiểu thuyết hư cấu và giả tưởng.

Nhưng viết code để tái sử dụng, giúp bạn các kỹ năng về suy nghĩ thấu đáo vấn đế, có lợi cho bạn, khi bạn nghĩ tới điều này, có nghĩa là bạn đang cô lập các vấn đề của mình giúp cho bạn nhìn nhận ra các vấn đề tốt hơn.

Nguyên tắc chia tách code theo class/module/package độc lập (decoupling)

Ngoài ra, ngày nay, các ngôn ngữ đều có các package management như Composer của PHP, npm của Nodejs, Go có Go Module v.v… Việc này, giúp cho không chỉ code, mà còn là tổ chức cho toàn bộ một môi trường lớn hơn, như kiến trúc cho công ty, thậm chí public chúng ta thành các open source để đóng góp cho người khác.

Nguyên tắc theo composition hơn là thừa kế (composition over inheritance)

Việc thừa kế dẫn đến sự phức tạp bởi chúng phụ thuộc lẫn nhau, và để tránh phụ thuộc chúng ta lại phải liên tục tạo ra các thừa kế chồng lấn lên nhau. Và chỉ có việc trace lại các tính năng từ ban đầu đã là sự phức tạp.

Bản thân thế giới máy tính được thiết kế từ điện tử, không phải sinh học, bản thân nó mình tin rằng có là một tổng thể các thành phần độc lập và được gắn lại với nhau. Do do vậy, việc lập trình cơ bản cũng là các thành phần độc lập được gắn với nhau thông qua các interface, và giao tiếp qua các interface.

Lời kết

Vậy còn theo các bạn, nguyên tắc của các bạn là gì nào?

Chia sẻ bài viết ngay