Làm thế nào để trở thành người phát triển phần mềm tốt

GS John Vu24/01/2025 12:00
Làm thế nào để trở thành người phát triển phần mềm tốt

Tôi nhận được email từ một người bạn hỏi về cách đánh giá người phát triển phần mềm để xác định ai tốt ai xấu.

Sau đây là câu trả lời của tôi:

Để bắt đầu, bạn nên biết về chất lượng của mã mà người ta viết ra. Giả sử bạn có một người phát triển phần mềm có thể viết được một nghìn dòng mã một ngày. Người đó có phải là người phát triển phần mềm lớn không? Không nhất thiết đâu nếu người đó có nhiều lỗi. Tất nhiên người đó phải sửa chúng nhưng cứ mười lỗi người đó sửa, người đó lại tạo ra thêm năm lỗi nữa thì đến cuối cùng, người đó vẫn cò nhiều mã bị lỗi.

Theo ý kiến tôi, người phát triển phần mềm nên được đánh giá dựa trên phẩm chất chứ KHÔNG dựa trên số lượng mã. Người phát triển phần mềm tốt nên biết mã chất lượng là gì và làm việc cẩn thận để tạo ra mã tốt, người đó nên biết cần mất bao lâu để làm công việc và lập kế hoạch công việc tương ứng, kể cả viết các trường hợp kiểm thử trước khi người đó bắt đầu viết mã.

Người phát triển phần mềm lớn nên hiểu rõ ràng vấn đề trước khi giải quyết nó. Người đó nên viết các yêu cầu ra và đề nghị gặp gỡ với khách hàng để thảo luận cách người đó sẽ thực hiện chúng dựa trên điều người đó hiểu vấn đề. Người phát triển phần mềm lớn biết rằng đáp ứng yêu cầu của khách hàng là then chốt cho thành công dự án và người đó muốn tránh việc giải quyết vấn đề sai.

Người đó muốn chắc điều người đó viết trong tài liệu đích xác là vấn đề khách hàng muốn làm việc tiếp. Nếu có hoài nghi nào, người đó sẽ hỏi các câu hỏi để đảm bảo rằng người đó hiểu hoàn toàn điều người đó phải làm. Ngay cả khi người đó hiểu các yêu cầu, người đó sẽ KHÔNG nhảy vào viết mã ngay mà nghĩ về các cách khác để giải quyết vấn đề và xác định giải pháp tốt nhất và thời gian cần để thực hiện nó.

Người phát triển phần mềm lớn sẽ phân tích cẩn thận giải pháp để xác định cách nó sẽ tác động lên công việc của các thành viên khác trong tổ và cách những người khác sẽ tác động lên việc của mình. Người đó sẽ dành thời gian để hiểu mối tương quan giữa các cấu phần trong dự án vì người đó không làm việc một mình.

Người phát triển phần mềm tốt phải là thành viên tổ tốt bởi vì người đó hiểu chiều hướng của dự án, không chỉ về phần mềm mà về các thành viên khác của tổ nữa. Người đó biết cách vấn đề cần được giải quyết thế nào cùng với mọi người như một tổ. Người phát triển phần mềm tốt kết thúc dự án của họ đúng thời gian nhưng cũng chăm nom về tổ và sẵn sàng giúp người khác khi cần.

Người phát triển phần mềm mà không thể làm việc được trong tổ, thì không thể chia sẻ được thông tin với tổ, và không thể đóng góp được cho thành công của tổ sẽ KHÔNG là người phát triển tốt. Người thích làm việc một mình hay muốn là “anh hùng” KHÔNG có chỗ trong dự án phần mềm bởi vì CÔNG VIỆC PHẦN MỀM LÀ CÔNG VIỆC TỔ.

Người phát triển phần mềm lớn bao giờ cũng nghĩ những điều mới, tìm ra các công nghệ mới, thường xuyên cập nhật kĩ năng của mình một cách dự ứng. Người đó không chờ đợi người quản lí yêu cầu mình phải tham gia khoá đào tạo, hay đọc sách để cải tiến kĩ năng.  Người phát triển phần mềm lớn cũng có khả năng học từ người khác. Bằng việc làm cho mình thành người học cả đời, người đó có thể hấp thu tri thức mới vì người đó học từ các thành viên tổ của mình và từ người khác. Với người đó, mọi người đều có thể là thầy giáo.

Bằng việc đọc qua ở đây, một số trong các bạn có thể nói: “Đó là nhiều việc cho một người rồi. Như thế có quá lí tưởng không?” Tất nhiên, đó là nhiều việc nhưng đó là chỗ bạn muốn alf – người phát triển tốt. Tôi tin rằng bạn càng cải tiến kĩ năng của mình tốt hơn, bạn sẽ càng trở nên có cơ hội tốt hơn là bạn đã từng tưởng tượng.  Nếu bạn chọn việc nghĩ về bản thân mình là “đủ tốt rồi” và chẳng có gì thêm nữa để học, bạn bao giờ cũng sẽ chỉ là người lập trình. Nếu bạn không trưởng thành, bạn thậm chí không ở được cùng chỗ mà bạn bị ở sau khi người khác đang tiến bộ.

Nếu bạn làm việc cho một công ti, người quản lí của bạn sẽ đánh giá bạn để xác định liệu có đề bạt bạn hay không. Người phát triển tốt phải là người có trách nhiện với công việc của mình và với công ti của mình. Khi cần, người đó sẽ làm việc cần mẫn hay thậm chí làm cả vào ngày nghỉ cuối tuần để cho công việc được hoàn thành. Người đó sẽ về muộn nhất có thể được và nhận trách nhiệm về việc của mình.

Tất nhiên, điều này có thể không phải là nhất thiết vì người đó có thể được trả tiền cho việc làm thêm nhưng đó là dấu hiệu về người phát triển tốt. Một số người chỉ muốn làm việc theo giờ được trả lương thì họ có thể là người phát triển, nhưng họ sẽ không bao giờ là người phát triển lớn. Người phát triển lớn là người chơi theo tổ cho tới cuối, và coi tổ mình, nhóm mình như gia đình mình.

Có nhiều người phát triển trong công nghiệp, nhưng có ít người phát triển lớn. Tại sao?  Bởi vì ai đó chỉ muốn làm việc nhưng người khác lại yêu làm việc và họ làm với đam mê. Tôi tin không có đam mê về điều bạn làm, bạn sẽ không là người phát triển lớn. Thiếu đam mê là lí do số một mà nhiều người phát triển không bao giờ trở nên lớn.  Đó cũng là lí do số một để mọi người không thành công trong nghề của họ. Người phát triển đam mê sẽ làm tốt hơn bất kì ai không có đam mê về việc của họ, vai trò của họ và dự án của họ.

Người phát triển phần mềm lớn sẽ nói: “Tôi làm nó bởi vì tôi yêu nó.” Đó là điều người phát triển phần mềm lớn tất cả là gì, chăm nom, chuyên nghiệp và với nhiều đam mê.

Engish version

How to be a great software developer

I receive an email from a friend asking about how to evaluate a software developer to determine a good one from a bad one. Following is my answer:

To begin, you should know about the quality of code that the person wrote. Assume you have a software developer who can code thousand lines of code in a day. Is he a good software developer? Not necessary if he has a lot of defects. Of course he has to fix them but for every ten defects that he fixed, he caused five more defects so in the end, he still has a lot of defective code. In my opinion, software developer should be evaluated based on the quality NOT quantity of code. A good software developer should know what quality code is and carefully work to produce good code, he should know how long it would take to do the work and plan the works accordingly, including writing test cases before he even starts to code.

A good software developer should clearly understand the problem before solves it. He should write the requirements down in a document and request meeting with customer to discuss how he would implement them based on what he understands the problem. A good software developer knows that meeting customers’ requirements is the key for project success and he wants to avoid the issue of solving the wrong problem. He wants to make sure that what he writes in the document is exactly the problem that customers want him to work on. If there is any doubt, he will ask questions to ensure that he completely understands what he should do. Even when he understands the requirements, he will NOT jump into coding right away but thinks about various ways to solve the problem and determines the best solution and the time it takes to do it.

A good software developer will carefully analyze the solution to determine how it will impact other team member’s works and how other people will impact his works. He will spend time to understand the interrelationship between components in the project since he does not work alone. A good software developer should be a good team member because he understands the direction of the project, not only on his parts but other team members too. He knows how the problem should be solved together as a team. A good software developer finishes their projects on time but also care about the team and ready to help others when needed.

A software developer who can not work in team, can not share information with the team, and can not contribute to the success of a team will NOT be a good developer. A person who likes to work alone or want to be “A hero” has NO place in software project because SOFTWARE WORK IS TEAM WORK. A good software developer always learn new things, find out about new technologies, constantly updating his skills proactively. He does not wait for their managers to ask him to take a training course, or read books to improve the skills.  A good software developer also has the ability to learn from others. By making him a lifelong learner, he can absorbs new knowledge as he learns from his team members and from others. To him, everybody could be his teacher.

By reading through here, some of you may say: “That is a lot of works for a person. Is it too idealistic?” Of course, that is a lot of works but that is where you want to be – a good developer. I believe that the better you can improve your skill, the better chance you will become greater than you have ever imagined.  If you choose to think of yourself as “good enough” and have nothing more to learn, you will always be just a programmer. If you are not growing, you are not even stay in the same place but you are behind as others are making progress.

If you are working for a company, your manager will evaluate you to determine whether to promote you or not. A good developer must be a responsible person to his work and to his company. When needed, he will work hard or even come in on the weekend to get the work done. He will stay as late as possible and take responsibility for his works. Of course, this may not be a necessity since he may not get paid for the extra works but it is the sign of a good developer. Some people just want to work according to the paid hours then they could be developers, but they will never be great. Great developers are team players to the end, and view their team, their company like their family.

There are many developers in the industry, but there are few great developers. Why?  Because some only want to work but other love to work and they work with passions. I believe without passion in what you do, you will not be a great developer. Lack of passion is the number one reason so many developers never become great.  It is also the number one reason people do not succeed in their career. A passionate developer will outperform anyone without a passion about their job, their role, and their project.

A great software developer would say: “I do it because I love it”. That is what great software developer is all about, caring, professionalism and with lot of passions.

 


Gửi bình luận
(0) Bình luận
1

Nhu cầu cấp bách

Tuần trước, tôi đã viết về vài “khu vực nóng” trong thị trường công nghệ và tôi tin nền di động sẽ là một trong chúng trong vài năm tới.
2

Phần mềm di động

Phát triển ứng dụng di động là qui trình qua đó phần mềm được phát triển cho điện thoại di động hay thiết bị cầm tay tương tự.
3

Kinh nghiệm của kỹ sư phần mềm

“Em đã làm năm việc trong ba năm. Chẳng có gì để tự hào nhưng hồi tưởng lại, em đã học được bài học tốt và đó là lí do tại sao em quay lại thăm thầy.”
4

Lời khuyên từ bạn bè

Năm ngoái, một sinh viên năm thứ nhất nói với tôi trong ngày đầu tiên lên lớp: “Thầy nói cứ như là bố mẹ em nói, học, học và học nữa. Cuộc sống KHÔNG chỉ là học tập và là sinh viên đại học, em KHÔNG cần những lời khuyên có vẻ như của bố mẹ thế.”
5

Khu vực nào sẽ nóng

Tuần trước, một sinh viên năm thứ nhất ở Trung Quốc hỏi tôi: “Công nghệ thông tin là lĩnh vực lớn với nhiều miền đặc biệt. Em nên tập trung vào miền nào để khi em tốt nghiệp trong bốn năm nữa kể từ bây giờ, em sẽ có khả năng có việc làm tốt? Nếu em muốn làm việc ở Mĩ hay châu Âu tôi cần làm gì khác nữa?”

Bill Gates ở Đại học Thanh Hoa

Trong chuyến thăm lần thứ 10 tới Trung Quốc, chủ tịch Microsoft Corporation Bill Gates đã làm khuấy động ở Bắc Kinh

Việc làm

Tuần trước tôi nhận được email mà người viết nói “Tôi không có bằng cấp về khoa học máy tính hay kĩ nghệ phần mềm. Làm sao tôi có thể học để kiếm việc trong lĩnh vực máy tính?”

Xu hướng thị trường

Khi tôi đi tiến hành nghiên cứu về xu hướng phần mềm toàn cầu, tôi có thể thấy bằng chứng về cuộc khủng hoảng tài chính ở hầu khắc mọi nước với công nhân bị sa thải và các công ti phần mềm hết khả năng kinh doanh.

Lời khuyên cho người quản lí dự án phần mềm

Sau đây là đối thoại giữa người quản lí cấp cao (SM) người đưa ra lời khuyên cho người quản lí dự án phần mềm (PM)

CMU tại Trung Quốc

iCarnegie của Carnegie Mellon và iSofStone, một trong những công ti khoán ngoài hàng đầu của Trung Quốc, đã cùng là đối tác để mở học viện đào tạo cho các nhà chuyên nghiệp CNTT ở Vô Tích, Trung Quốc.

Vấn đề với dự án phần mềm

Theo nghiên cứu mới nhất về công nghiệp phần mềm Mĩ, nhiều dự án phần mềm vẫn thất bại với tỉ lệ cao mặc cho nhiều nỗ lực cải tiến.

Kỹ năng học tập

Kĩ năng học tập mới là điều quan trọng nhất để cải tiến và duy trì nghề nghiệp của bạn.

Tồn tại trong toàn cầu hoá

Bạn tôi, người quản lí một công ti phần mềm nói với tôi về cách cuộc khủng hoảng tài chính đã tác động lên doanh nghiệp của ông ấy.

Làm chủ ai -  Sách dành cho người muốn tìm hiểu về trí tuệ nhân tạo

Kể từ khi ChatGPT ra mắt, dường như ngày nào chúng ta cũng nghe nhắc đến AI và cách nó làm thay đổi thế giới xung quanh. Vậy rốt cuộc những công cụ này hoạt động ra sao? Và một người bình thường có thể sử dụng AI như thế nào? Quyển sách này sẽ giúp bạn trả lời những câu hỏi đó.

Một số sự kiện về cách tiếp cận Agile

Blog GS John VU - GS John Vu - 30/05/2026 12:00
Một sinh viên hỏi tôi: “Nếu Agile là cách tiếp cận tốt để phát triển phần mềm thì tại sao chúng ta phải học cách tiếp cận khác?”

Anthropic ra mắt "trợ lý AI ngành luật", thu hút hơn 20.000 người đăng ký

Kỹ năng - Lại Dịu - 30/05/2026 11:00
Anthropic đang biến Claude thành “trợ lý pháp lý AI” có thể kết nối trực tiếp với các phần mềm luật chuyên dụng, làm nóng thêm cuộc đua AI trong ngành pháp lý.

“Thần kinh doanh” Kazuo Inamori: Nếu không tài năng, cần biết 1 con đường “lợi hại” này để làm giàu

Suy ngẫm - Kim Linh - 30/05/2026 10:00
Theo tỷ phú Nhật Bản Inamori Kazuo, muốn trở thành một người giàu có và thành công cần có sự kiên nhẫn phi thường trong công việc.

Từ chiếc máy tính cũ, nam sinh Bách khoa thắng lớn với “Tiệm phở anh Hai”

Truyền cảm hứng - Mỹ Hà - 30/05/2026 09:00
Từ chiếc máy tính cũ và những dự án trò chơi âm thầm suốt nhiều năm, nam sinh Đại học Bách khoa Hà Nội tạo nên “cơn sốt” với “Tiệm phở anh Hai”, đồng thời thắng lớn hai giải thưởng.

Làm chủ ai -  Sách dành cho người muốn tìm hiểu về trí tuệ nhân tạo

Từ sách - Phim - Thu An - 30/05/2026 08:00
Kể từ khi ChatGPT ra mắt, dường như ngày nào chúng ta cũng nghe nhắc đến AI và cách nó làm thay đổi thế giới xung quanh. Vậy rốt cuộc những công cụ này hoạt động ra sao? Và một người bình thường có thể sử dụng AI như thế nào? Quyển sách này sẽ giúp bạn trả lời những câu hỏi đó.

Hệ thống giáo dục mới

Blog GS John VU - GS John Vu - 29/05/2026 12:00
Tôi để ba tuần giảng dạy ở Trung Quốc.

Lời khuyên cho tất cả những ai hay dùng ChatGPT tìm kiếm thông tin

Kỹ năng - Nhật Hạ - 29/05/2026 11:00
Để tận dụng AI hiệu quả mà vẫn an toàn, người dùng nên lưu ý một số điều dưới đây.

6 cách giúp bạn tăng cường từ trường cá nhân nhanh nhất, càng thực hiện đều may mắn đổ về càng nhiều

Suy ngẫm - Diêu Dương - 29/05/2026 10:00
Muốn gặp người tốt, cơ hội đẹp và chuyện thuận lợi hơn. Hãy bắt đầu bằng việc chỉnh lại từ trường cá nhân của chính mình. Sáu thói quen sau đây dễ làm, chi phí gần như bằng không nhưng hiệu quả thì thấy rõ từng ngày.

Hà Nội, một gia đình chi hơn 2 tỷ đồng làm “nhà di động” xuyên Việt 3-5 lần/năm

Phong cách sống - Mộc Khải - 29/05/2026 09:00
Năm 2022, khi mô hình du lịch bằng "nhà di động" còn khá mới ở Việt Nam, anh Nguyễn Ngọc Thắng (Hà Nội) đã bắt đầu tự cải tạo một chiếc xe 16 chỗ thành “nhà di động” đầu tiên của gia đình.

Không khóc giữa nhân gian

Tủ sách - FN - 29/05/2026 08:00
Đau khổ vốn không trừ một ai, và nó có trăm hình vạn trạng: một sự mất mát, cảm giác cô độc giữa đám đông, hay đơn giản là nỗi thất vọng khi không đạt được thứ mà mình mong chờ. Vậy phải làm sao để ta hết khổ? Đau khổ có thực sự đáng sợ như người ta vẫn nghĩ? Hay chúng ta vẫn có thể nhìn đau khổ dưới một góc độ bao dung hơn?

Phần mềm di động

Blog GS John VU - GS John Vu - 28/05/2026 12:00
Phát triển ứng dụng di động là qui trình qua đó phần mềm được phát triển cho điện thoại di động hay thiết bị cầm tay tương tự.

WhatsApp biến phòng chat AI thành khu vực "bất khả xâm phạm", Mark Zuckerberg muốn đọc cũng phải bó tay!

Kỹ năng - Anh Phương - 28/05/2026 11:00
Với chế độ ẩn danh sắp ra mắt trên WhatsApp, CEO Mark Zuckerberg khẳng định đây là sản phẩm AI lớn đầu tiên trên thế giới hoàn toàn không lưu trữ lịch sử hội thoại trên máy chủ nhằm bảo vệ quyền riêng tư tuyệt đối cho người dùng.

Bậc thầy EQ luôn mang theo 8 chữ: Chính Lưu Bị cũng ‘giắt túi’ để tránh tai hoạ

Suy ngẫm - Diệu Đan - 28/05/2026 10:00
Khi đối mặt với những lời khiêu khích và lăng mạ, ông điềm đạm, không tranh hơn thua. Khi đối mặt với những lợi nhuận nhỏ và những cám dỗ, ông bình tĩnh không tranh hơn thiệt. Ấy chính là cách đối đãi của bậc cao thủ!

“Thế hệ dâu tây”: Đi làm mệt quá thì nghỉ, việc khó quá không làm nữa là xong

Phong cách sống - Ngọc Linh - 28/05/2026 09:00
Khả năng chịu khổ và vượt khó “bằng 0”.

Minh triết từ nỗi bất an: Cái nhìn sáng suốt về sự bất định của đời sống

Từ sách - Phim - Minh Hằng - 28/05/2026 08:00
Giữa một thế giới đầy rẫy những biến động khó lường, "Minh triết từ nỗi bất an" nhắc nhở chúng ta rằng điểm tựa vững chắc, kiên cố nhất của một con người không bao giờ nằm ở một thế giới vật chất bên ngoài, mà ở ngay khả năng dũng cảm hòa mình vào dòng chảy của hiện tại, bởi vì ngay trong chính sự vô định đó, bạn sẽ tìm thấy sự tự do đích thực của tâm hồn.
HẠT GIỐNG TÂM HỒN
2019 Bản quyền thuộc về hatgiongtamhon.com.vn. Phát triển bởi ONECMS