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

Làm việc theo tổ

Trong cuộc họp, nhiều cựu sinh viên tới gặp tôi kể về việc “Làm việc theo tổ”. Họ bảo tôi rằng họ đã làm việc trong tổ xây dựng phần mềm nhưng khi tôi hỏi thêm các câu hỏi, dường như là họ đã làm việc “trong nhóm” mà KHÔNG “trong tổ”.

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.

Vì sao iPhone có 2 màn hình cuộc gọi?

Kỹ năng - Cẩm Bình - 06/05/2025 14:00
Khi iPhone nhận cuộc gọi, người dùng sẽ thấy có 2 màn hình khác nhau.

Làm việc theo tổ

Blog GS John VU - GS John Vu - 06/05/2025 13:00
Trong cuộc họp, nhiều cựu sinh viên tới gặp tôi kể về việc “Làm việc theo tổ”. Họ bảo tôi rằng họ đã làm việc trong tổ xây dựng phần mềm nhưng khi tôi hỏi thêm các câu hỏi, dường như là họ đã làm việc “trong nhóm” mà KHÔNG “trong tổ”.

Xem "Sex Education", tôi nhận ra sai lầm khiến bản thân rơi vào cảnh lạc lõng, mất định hướng cuộc đời

Điện ảnh - Ứng Hà Chi - 06/05/2025 12:00
Thông qua bộ phim, tôi nhận được bài học để đời, giúp tôi tìm được những điều ý nghĩa trong cuộc sống.

AI - chìa khóa của sự tiện lợi và chuyển đổi số

Kỹ năng - Hải An - 06/05/2025 11:00
Từ trợ lý nhà thông minh đến các lĩnh vực giải trí, làm đẹp, chăm sóc sức khỏe, giáo dục..., trí tuệ nhân tạo (AI) đang hiện diện ở mọi nơi, mang lại nhiều lợi ích vượt trội và giúp nâng cao hiệu quả công việc.

Bài học quan trọng nhất từ ​​sai lầm lớn của OpenAI với ChatGPT

Suy ngẫm - Sơn Vân - 06/05/2025 10:00
OpenAI đã mắc lỗi trong một bản cập nhật ChatGPT vào cuối tháng 4 và vừa đăng bài viết thừa nhận sai lầm.

Ánh sáng trong ta - Bạn có được nhìn nhận với con người mình?

Từ sách - Phim - TĐ - 06/05/2025 09:00
Bạn đã bao giờ cảm thấy mình không quan trọng chưa? Bạn có từng cảm thấy mình tồn tại trong một thế giới xem mình như vô hình?

Hạnh phúc đến từ sự biến mất - Hành trình tìm hạnh phúc của Ajahn Brahm

Từ sách - Phim - Quìn - 06/05/2025 08:00
Hạnh phúc không đến từ việc “có thêm”, mà đến từ việc “buông bỏ”. Đó chính là điều mà thiền sư Ajahn Brahm – trụ trì tu viện Bodhiyana (Tây Úc) gửi gắm trong "Hạnh phúc đến từ sự biến mất" (The art of disappearing).

Xem Sex Education, một câu thoại khiến tôi nhận ra mình đối xử tệ đến mức nào với con cái

Điện ảnh - Thanh Hương - 05/05/2025 13:00
Gia đình tôi đã thấu hiểu nhau hơn sau sự cố này.

Cách kiểm tra ngay tài khoản Zalo, Facebook của bạn có đang bị đọc trộm tin nhắn hay không

Kỹ năng - Nhật Hạ - 05/05/2025 12:00
Thử kiểm tra xem Zalo, Facebook của bạn có bị đọc trộm tin nhắn không bằng những cách sau.

Cuộc chiến ngầm của Meta: Email nội bộ hé lộ căng thẳng giữa Facebook và Instagram

Thư giãn - Sơn Vân - 05/05/2025 11:00
Gia đình nào cũng có một số chuyện rắc rối, và vấn đề nội bộ của Meta Platforms đã bị đưa ra ánh sáng khi tòa án công bố các tài liệu những ngày gần đây.

Hiểu 3 quy luật đổi vận mệnh, kiếm tiền trong tầm tay

Suy ngẫm - Như Nguyễn - 05/05/2025 10:00
"Của cải trung bình 7 năm chuyển giao một lần, đằng sau mỗi một lần chuyển giao là sự điều khiển của công nghệ”, Founder một công ty lớn khẳng định.

Xu hướng sách phi hư cấu thế kỷ 21 bộc lộ bản chất con người

Từ sách - Phim - Theo Znews - 05/05/2025 09:00
Gần 1/4 thế kỷ đã qua, danh sách tác phẩm ăn khách của The Sunday Times cùng số liệu thống kê do Nielsen BookData cung cấp cho thấy văn học phi hư cấu và sở thích đọc sách của độc giả Anh phần nào đã thay đổi.

Ánh sáng trong ta - Cuốn sách thứ hai của bà Michelle Obama, top 100 sách phải đọc năm 2022

Từ sách - Phim - HỒ LAM - TTO - 05/05/2025 08:00
Ánh sáng trong ta, cuốn sách ra đời sau hồi ký bán chạy toàn cầu Chất Michelle của cựu Đệ nhất phu nhân Michelle Obama, chia sẻ những kiến thức thực tế để luôn duy trì hy vọng, sự cân bằng trong một thế giới không ngừng đổi thay.

31 câu nói của Đức Đạt Lai Lạt Ma thứ 14 về tình yêu, hòa bình và lòng từ bi

Suy ngẫm - TĐ - 04/05/2025 13:00
 Đức Đạt Lai Lạt Ma là danh hiệu lãnh đạo tinh thần của Phật giáo Tây Tạng. Trong tiếng Mông Cổ, Đạt Lai có nghĩa là “đại dương” hay “rộng lớn” và trong tiếng Tây Tạng, “Lạt Ma” có nghĩa là “bậc thầy” hoặc “đạo sư”.

Cách kiểm tra tài khoản Google có bị đăng nhập trái phép hay không

Kỹ năng - Cẩm Bình - 04/05/2025 12:00
Tài khoản Google gắn liền với công việc lẫn nhiều hoạt động trực tuyến, vì vậy ta cần định kỳ kiểm tra xem có ai ngoài bản thân đăng nhập hay không.
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
Thứ 3, 06/05/2025