Các nguyên tắc lập trình mà lập trình viên nên biết

5878
nguyên tắc lập trình

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ậy làm sao để quá trình đó trở nên tốt hơn, tốt hơn từ lúc bắt đầu viết code? Người ta bắt đầu nghĩ về các nguyên tắc 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.

Cùng tìm hiểu về các nguyên tắc lập trình này nhé!

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 tắc 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 tắc. 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 lập trình đò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:

  • Các thành viên trong team có thể tuân theo dễ dàng.
  • Sau này người mới cũng dễ dàng tiếp nhận
  • Bản thân chúng ta sau này đọc lại để improve, maintain cũng dễ dàng.
  • Đặc biệt, khi chúng đơn giản thì hỏng hóc sẽ dễ dàng sửa chữa.

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, ngà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.

  • Hãy chia cái hàm to thành nhiều hàm nhỏ hơn.
  • Đừng viết các thuật toán, giải thuật gì đó kiểu như optimize cái này cái kia, tiết kiệm cái này cái khác, rồi làm mớ code trở nên khó hiểu.

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ẽ. 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ẽ:

  • Hãy tạo cho mình một bộ nguyên tắc (Coding Convention)
  • Hãy bắt đầu bằng việc đặt tên biến gọn gàng, dễ hiểu
  • Hãy thiết kế các function có tên dễ đọc, dễ hiểu
  • Hãy làm cho các function có input và output rõ ràng
  • Bên trong các function hạn chế if/else/for một cách quá so deep

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ết 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)

  • Mỗi class nên chỉ làm một việc duy nhất, do vậy chia tách chương trình thành nhiều class khác nhau.
  • Mỗi module/package cũng chỉ nên làm các công việc thuộc về domain của nó.
  • Bên trong mỗi class/module/package hide đi các implement không cần thiết phải public ra.

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.

  • Hãy quan sát các tiến bộ gần đây như React là các component được gắn với nhau.
  • Hãy để ý rằng Go với việc embedded các struct.
  • Hãy để ý rằng ngày nay, PHP có trait.

Lời kết

Hy vọng với một số nguyên tắc lập trình trên, các bạn có thể code tốt hơn trước.

Cảm ơn các bạn đã theo dõi bài viết!

Đừng bỏ lỡ những bài viết hay dành cho lập trình viên:

Xem thêm việc làm Software Developers hấp dẫn trên TopDev

TopDev via viblo.asia