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

Trở lại chuyện kiểm thử phần mềm

Một sinh viên mới tốt nghiệp, làm việc cho một công ti phần mềm gặp tôi nói: “Tôi làm việc là người kiểm thử phần mềm, tôi kiểm thử mọi thứ rất cẩn thận nhưng khách hàng của tôi vẫn tìm ra lỗi. Tôi đã làm gì sai và tôi có thể làm gì để là người kiểm thử giỏi hơn?”

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.

Xem phim "Sex Education", tôi nhận ra mình đang sống lỗi với con trong mối quan hệ cha con

Điện ảnh - Mỹ Hạnh - 02/06/2025 13:00
Tôi nhận thấy mình không hiểu con. Và mối quan hệ cha con ngày càng trở nên căng thẳng.

Từng được ca tụng là "nghề hot của kỷ nguyên AI", giờ bị chính AI "khai tử"

Kỹ năng - Anh Việt - 02/06/2025 12:00
Đây là bài học cảnh tỉnh cho bất kỳ ai đặt hy vọng vào những làn sóng nghề mới từ AI: thứ nổi lên nhanh thì cũng có thể mất đi trong tích tắc.

Viễn cảnh gì sẽ xảy ra khi sau 1 giấc ngủ tất cả các app chat trên đời đều đồng loạt biến mất?

Thư giãn - Trần Hà - 02/06/2025 11:00
Điều đầu tiên chắc chắn là cảm giác hoang mang vì... mất kết nối.

Lời nói gan ruột của người mẹ: "Tình yêu không đến từ những bảng điểm đẹp!"

Suy ngẫm - Huyên Nguyễn - 02/06/2025 10:00
"Tôi đã từng nhiều lần thất vọng … và rồi chợt nhận ra rằng, tình yêu thương thật sự không đong đếm bằng những bảng điểm đẹp hay những lời khen ngợi...", cô Diệp Quỳnh chia sẻ.

Cất 100.000-150.000 đồng/ngày trong suốt 2 năm để "phát lương hưu" cho bố mẹ

Truyền cảm hứng - Ngọc Linh - 02/06/2025 09:00
Cũng là để dành tiền nhưng lại không phải tiết kiệm cho bản thân, chia sẻ của cô gái này thật sự quá đáng yêu!

Khai mở cảm xúc - Hiểu đúng về tội lỗi và xấu hổ

Từ sách - Phim - TĐ - 02/06/2025 08:00
Sự xấu hổ thực chất gắn liền với sức khỏe tâm thần. Ta xấu hổ khi cảm thấy khổ sở, buồn bã hoặc lo lắng, nỗi xấu hổ này tạo ra những cảm xúc khó khăn hơn nữa, làm sức khỏe tinh thần thêm kém.

Mẹ sử dụng lò vi sóng theo cách rất tiện lợi lại tốt cho sức khỏe

Kỹ năng - Mỹ Diệu - 01/06/2025 12:00
Có thể bạn nghĩ rằng lò vi sóng chỉ có thể dùng để hâm nóng đồ ăn. Nhưng hãy để tôi cho bạn thấy cách mẹ tôi dùng nó, đúng là "gừng càng già càng cay"!.

Vì sao Âu Dương Phong hễ thấy hai cao thủ này là né tránh?

Thư giãn - Nguyệt Phạm - 01/06/2025 11:00
Điều gì ẩn giấu đằng sau thái độ khác biệt này của Âu Dương Phong?

Người đàn ông rong ruổi các tỉnh miền Tây chụp biển địa giới trước sáp nhập

Phong cách sống - Nguyễn Ngoan - 01/06/2025 10:00
Nghe tin các tỉnh miền Tây quê mình dự kiến sáp nhập, anh An dành 3 ngày chạy xe máy đến từng biển địa giới chụp ảnh lưu giữ kỷ niệm.

5 bài học dạy con của ''Vua dầu mỏ'' Rockefeller giúp gia tộc giàu 7 đời

Suy ngẫm - Khuê Hiền - 01/06/2025 09:00
Tỷ phú Rockefeller luôn đánh giá cao sự nỗ lực của mỗi cá nhân trên chặng đường làm giàu.

Khai mở hạnh phúc - Sáu lầm tưởng về hạnh phúc

Từ sách - Phim - TĐ - 01/06/2025 08:00
Chúng ta đã bắt đầu quyển sách bằng cách tìm hiểu xem hạnh phúc là gì, giờ là lúc để nghĩ xem hạnh phúc không phải là gì. 

Không phải Nữ Oa hay Tây Vương Mẫu, đây là nữ thần có thể giết Tôn Ngộ Không

Điện ảnh - Nguyệt Phạm - 31/05/2025 13:00
Bà là một vị thần quan trọng trong các tín ngưỡng dân gian.

Dịch vụ giúp "biến mất" khỏi Internet

Kỹ năng - Thái Nguyễn - 31/05/2025 12:00
Từ nhu cầu xóa dấu vết online đến dịch vụ “ẩn thân kỹ thuật số” bùng nổ, câu chuyện biến mất khỏi Internet đang dần trở thành trào lưu thời hiện đại.

Kiếm hiệp Kim Dung: Điều gì giúp Quách Tĩnh thắng được 4 cao thủ Ngư - Tiều - Canh - Độc?

Thư giãn - Quốc Tiệp - 31/05/2025 11:00
Chính sự kết hợp giữa sự chân thành của Quách Tĩnh và trí thông minh của Hoàng Dung đã giúp họ đến gặp được Nhất Đăng đại sư.
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, 03/06/2025