Quy trình phần mềm

GS John Vu01/07/2024 12:00
Quy trình phần mềm

Tuần trước, một sinh viên nói với tôi: “Phần mềm quá phức tạp và không thể nào loại bỏ mọi lỗi được. Em càng thử phần mềm, càng tìm ra nhiều lỗi hơn, và càng chữa các lỗi đó, lại càng nhiều lỗi xuất hiện thêm”.

Tôi hiểu thất vọng của sinh viên này bởi vì không thể nào loại bỏ được các lỗi dựa trên việc kiểm thử.

Tôi làm việc trong công ti hàng không và tôi có thể nói với bạn rằng máy bay là hệ thống phần cứng và phần mềm phức tạp. Mặc dầu không ai có thể chứng minh được rằng máy bay không có khiếm khuyết nhưng công ti chúng tôi nhận trách nhiệm về mọi khiếm khuyết. Tuy nhiên, chúng tôi không dựa vào việc kiểm thử sản phầm để loại bỏ khiếm khuyết bởi vì chúng tôi biết rằng kiểm thử là cách rất tốn kém và không hiệu quả để khử bỏ khiếm khuyết.

Chúng tôi tập trung vào tuân theo các qui trình phát triển và chế tạo đã được xác định rõ, chúng tôi dùng các thủ tục đo được và các phương pháp thống kê để xây dựng mọi thứ đúng đắn ngay từ đầu. Tất nhiên chúng tôi làm kiểm thử sản phẩm của mình nhưng kiểm thử là nỗ lực cuối cùng để đảm bảo sản phẩm có chất lượng rất cao.

Câu hỏi của tôi là tại sao công nghiệp phần mềm không thể áp dụng điều mà công nghiệp chế tạo đã từng làm trong nhiều năm rồi? Điều đó đưa tôi tới một câu hỏi nền tảng khác tại sao người làm phần mềm lại không được dạy về qui trình phần mềm? Tại sao phần lớn các đại học vẫn dạy sinh viên về ngôn ngữ lập trình và kiểm thử mà không dạy về qui trình phát triển phần mềm?

Qui trình là dãy các bước được thực hiện theo một lí do nào đó. Qui trình tích hợp con người, thủ tục và công cụ để tạo ra sản phẩm cuối cùng. Sản phẩm có thể là máy bay, xe hơi, điện thoại di động hay phần mềm máy tính. Qui trình là điều mọi người làm, dùng các thủ tục, phương pháp, công cụ và trang thiết bị để biến đổi vật liệu thô như gỗ, kim loại thành sảnh phẩm như nhà, xe hơi. Qui trình phần mềm là tập các bước  (kể cả thủ tục, phương pháp và công cụ) mà mọi người tuân theo để phát triển sản phẩm phần mềm. Khái niệm then chốt ở đây là chỗ chất lượng của sản phẩm được xác định bằng chất lượng của qui trình được dùng để phát triển nó.

Cho nên khi sản phẩm có lỗi, bạn phải quay lại qui trình và nhận diện cái gì là nguyên nhân, nó xảy ra ở đâu trong qui trình và sửa nó để cho nó sẽ không xảy ra nữa. Bằng việc áp dụng phương pháp thống kê để đo mọi bước trong qui trình, người kĩ sư có thể tạo ra một miền có hiệu quả các kết quả được trông đợi mà có thể đạt tới được bằng việc tuân thủ theo qui trình phần mềm. Bằng việc cải tiến liên tục qui trình và loại bỏ nguyên nhân lỗi, người kĩ sư phần mềm có thể tạo ra sản phẩm phần mềm với ít khiếm khuyết hơn. Tôi thận trọng không nói “không lỗi” ở đây bởi vì khó chứng minh được điều đó nhưng phần mềm với thật ít lỗi thì tốt hơn là phần mềm đầy lỗi.

Khái niệm về qui trình là yếu tố then chốt trong giáo trình phần mềm mới có tên là Kĩ nghệ phần mềm. Trong lĩnh vực này, sinh viên sẽ học việc áp dụng cách tiếp cận có kỉ luật và có định lượng vào việc phát triển phần mềm. Kỉ luật này bao gồm tri thức, công cụ và phương pháp xác định yêu cầu, kiến trúc hệ thống phần mềm, thiết kế và thực hiện sản phẩm phần mềm, tiến hành kiểm thử và kiểm chứng rằng sản phẩm đáp ứng yêu cầu. Triết lí của bộ môn này là chất lượng phần mềm thuộc vào trách nhiệm của người làm phần mềm, người tạo ra sản phẩm phần mềm. Tuy nhiên, nếu người làm phần mềm không cải tiến kĩ năng của mình, không phân biệt giữa “kĩ nghệ phần mềm” và “lập trình phần mềm” thì ngành công nghiệp phần mềm không thể đi rất xa được. Chừng nào mà người làm phần mềm vẫn cứ khăng khăng rằng chất lượng không phải là trách nhiệm của họ, thì chất lượng không thể được cải thiện.

English version

Process

Last week, one student told me: “Software is so complex and it is impossible to remove all defects. The more I tested software, the more defects I found and the more I fixed those defects, the more defects appeared”. I understand his frustration because it is not possible to remove defects based on testing alone.

I work in an aerospace company and I can tell you that an aircraft is a complex hardware and software systems. Although no one can prove that the aircraft has zero defects but our company does take full responsibility for any defects. However, we do not rely on product testing to remove defects because we know that testing is very expensive and ineffective way to eliminate defects. We focus on following a well defined development and manufacturing processes, we use measured procedures and statistical methods to build everything corrected from the beginning. Of course we do test our products but testing is the last resort to ensure the products are of very high quality.

My question is why software industry can not apply what the manufacturing industry has been doing for years? That brings me to another fundamental question why software people are not taught about software process? Why most universities are still teaching students about programming languages and testing but not the process of develop software?

Process is a sequence of steps performed for a given reason. Process integrates people, procedures and tools to create a final product. The product can be an aircraft, a car, a mobile phone or computer software.  Process is what people do, using procedures, methods, tools, and equipments to transform raw materials such as wood, metal into a product such as a house, a car. A software process is a set of steps (including procedures,
methods and tools) that people follow to develop software product. The key concept here is that the quality of the product is determined by the quality of the process used to develop it. So when the product has defect, you must go back to the process and identify what is the cause, where does it happen in the process and fix it so it will not happen again. By apply statistical method to measure every process steps, engineer can effective create a range of expected results that can be achieved by following a software process. By continuously improve the development process and remove the cause of defects, a software engineer can produce software product with much fewer defects. I am carefully not to say “Zero defects” here because it is difficult to prove it but software with much fewer defects is better than software full of defects.

The concept of process is the key element in a new software curriculum called Software Engineering. In this field, students will learn the application of a disciplined and quantifiable approach to the development of software. This discipline consists of knowledge, tools, and methods for defining requirements, architect a software system, design and implement software products, conduct testing and verify that the product meet
requirements. The philosophy of this discipline is software quality is the responsible of software people who create the software product. However, if software people do not improve their skills, do not distinguish between the “engineering of software” and the “programming of software” then the software industry cannot go very far. As long as software people insist that quality is not their responsibility, quality cannot be improved.

 


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

Giáo sư John Vu – Nguyên Phong bàn về AI trong giáo dục

Nói về việc đưa trí tuệ nhân tạo (AI) vào giáo dục, Giáo sư John Vu – Nguyên Phong cho rằng AI có thể hỗ trợ, nhưng tuyệt đối không thể thay thế vai trò của giáo viên trong việc định hình nhân cách cho thế hệ trẻ.
2

Bàn về AI, GS John Vu nói thẳng: Nếu máy móc vượt trội, con người sẽ trở nên vô giá trị và có thể bị đào thải

Nói về việc đưa trí tuệ nhân tạo (AI) vào giáo dục, Giáo sư John Vu – Nguyên Phong cho rằng AI có thể hỗ trợ, nhưng tuyệt đối không thể thay thế vai trò của giáo viên trong việc định hình nhân cách cho thế hệ trẻ.
3

Người lập trình hay người phát triển

Tuần trước tôi nhận được một email hỏi: “Khác biệt giữa người lập trình và người phát triển phần mềm là gì? Người lập trình có thể trở thành người phát triển được không?

Người quản lý dự án phần mềm

Hàng nghìn năm trước đây, triết gia Hi Lạp Socrates đã dạy học trò của mình “Tự biết mình”. Ngày nay, tôi muốn dùng cùng cách tiếp cận đó trong kĩ nghệ phần mềm bằng việc gợi ý rằng người quản lí dự án phần mềm.

Học tập

Khái niệm về học tập đang đối diện với những thay đổi nền tảng do sự thay đổi trong công nghệ và nền kinh tế toàn cầu.

Người kỹ sư phần mềm giỏi nhất

Bạn tôi hỏi tôi: Làm sao anh biết người kĩ sư phần mềm giỏi nhất so với người trung bình? Sau đây là ý kiến cá nhân của tôi:

Kỹ nghệ: Ham muốn đột nhiên xảy tới cho sinh viên tốt nghiệp đại học

Khi cuộc khủng hoảng tài chính sâu sắc thêm, sinh viên tốt nghiệp khoa học và toán học, những người đã có thời lũ lượt kéo vào Kinh doanh, Tài chính và Ngân hàng, bây giờ đang xem xét việc làm trong kĩ nghệ phần mềm.

Cần hỗ trợ cho nền kinh tế dựa trên tri thức

Khi thế giới bước vào thế kỉ 21, nền kinh tế toàn cầu trở thành nền kinh tế dựa trên tri thức.

Nền kinh tế dựa trên tri thức

Có một báo cáo đại học nói rằng 34% thanh niên giữa độ tuổi 18 tới 32 đang hoặc lập kế hoạch để khởi đầu doanh nghiệp hay đã làm việc đó rồi.

Nền kinh tế tri thức-5

Ngày nay, dẫn lái chính cho tăng trưởng kinh tế là trong miền công nghệ cao.

Nền kinh tế tri thức-4

Là một giáo sư lịch sử, bạn tôi rất tò mò về điều đã xảy ra ở Ấn Độ cho nên ông ấy hỏi: “Theo quan điểm của ông thì Ấn Độ rất thành công trong việc xây dựng xã hội tri thức bằng việc bỏ qua pha công nghiệp nhưng tại sao họ đã làm loại quyết định đó?”

Taylor Swift và “Thuyết mặc kệ họ”, để sống thật với chính mình

Ai cũng từng loay hoay vì ánh nhìn người khác. Taylor Swift cũng vậy, cho đến khi cô học cách buông bỏ và đặt câu hỏi: “Mình thực sự hạnh phúc vì điều gì?” Chính lúc ấy, hành trình “mặc kệ họ” đã mở ra kỷ nguyên rực rỡ nhất trong sự nghiệp của cô.

'Say một đời vì em' không phải AI sáng tác, mà có nữ tác giả

Giải trí - Ngọc Thanh - 03/10/2025 13:00
Say một đời vì em” đang là một trong những hiện tượng âm nhạc gây chú ý nhất trên mạng xã hội thời gian gần đây.

Xem Sex Education, tôi đem câu này dạy con: Nhìn sự thay đổi tích cực của con mà mừng!

Điện ảnh - Thanh Hương - 03/10/2025 12:00
Con ngơ ngác không hiểu hết ý, nhưng tôi thấy ánh mắt con sáng lên – như thể được công nhận.

Cách để bạn tăng thêm quyết tâm đọc sách

Kỹ năng - TĐ - 03/10/2025 11:00
Đối với những người yêu sách, việc có quyết tâm đọc thêm nhiều sách rất quan trọng. Vì vậy, nếu bạn yêu thích việc đọc sách và đang nghĩ đến việc đặt ra những mục tiêu trong việc đọc sách cho mình, hãy tham khảo những lời khuyên dưới đây nhé!

2 lần suýt chết, đây là những gì tôi nhìn thấy thế giới bên kia nơi cái chết cận kề

Suy ngẫm - Tuấn Khang - 03/10/2025 10:00
Qua 2 lần trải qua cận tử, người phụ nữ này đã chứng kiến những khung cảnh siêu nhiên mà cô không bao giờ có thể quên. Cô chia sẻ về những trải nghiệm lay động sâu sắc và những suy tư về cuộc sống, cái chết, và sự tồn tại vượt lên trên sự hiểu biết thông thường.

Taylor Swift và “Thuyết mặc kệ họ”, để sống thật với chính mình

Từ sách - Phim - Quìn - 03/10/2025 09:00
Ai cũng từng loay hoay vì ánh nhìn người khác. Taylor Swift cũng vậy, cho đến khi cô học cách buông bỏ và đặt câu hỏi: “Mình thực sự hạnh phúc vì điều gì?” Chính lúc ấy, hành trình “mặc kệ họ” đã mở ra kỷ nguyên rực rỡ nhất trong sự nghiệp của cô.

Cội nguồn của hạnh phúc

Tủ sách - FN - 03/10/2025 08:00
Từ xưa đến nay, nhân loại vẫn luôn đau đáu về những câu hỏi cơ bản như làm thế nào để có hạnh phúc, và cội nguồn của hạnh phúc là gì.

Tâm đắc 4 bài học Lưu Diệc Phi gửi gắm trong "Đi đến nơi có gió", phụ nữ càng nên nhớ

Điện ảnh - Tích Thành - 02/10/2025 12:00
Bộ phim "Đi đến nơi có gió" không chỉ là một thước phim đẹp mà còn là cuốn sách chỉ dẫn quý giá. 4 bài học từ nhân vật Hứa Hồng Đậu dưới đây sẽ giúp phụ nữ sống an nhiên, tự tại và mạnh mẽ hơn.

Người dùng điện thoại Android được cập nhật nhiều tính năng hữu ích

Kỹ năng - Nam Đoàn - 02/10/2025 11:00
Bản cập nhật mới nhất từ Google đã mang đến nhiều tính năng hữu ích nâng tầm trải nghiệm người dùng, nổi bật với bảo mật chống các cuộc tấn công mạng, cuộc gọi lừa đảo.

Câu chuyện sau bức ảnh kinh điển biến Marilyn Monroe thành ngôi sao

Phong cách sống - Mi Vân - DT - 02/10/2025 10:00
Bức ảnh ghi lại khoảnh khắc biểu tượng gợi cảm Marilyn Monroe diện chiếc váy yếm trắng tung bay trên ga tàu điện trong phim “The Seven Year Itch” đã trở nên kinh điển trong nhiều thập kỷ.

Trở về từ cõi chết - Ánh sáng đôi khi chỉ lóe lên sau bóng tối

Từ sách - Phim - Quìn - 02/10/2025 09:00
Chữa lành - hai chữ nghe tưởng nhẹ nhõm, nhưng thực ra đó là hành trình gian nan. Có khi, chỉ sau khi đi qua tận cùng khổ đau, con người mới nhận ra giá trị của sự sống. Hành trình đặc biệt ấy được Anita Moorjani ghi lại trong cuốn sách "Trở về từ cõi chết" (Dying to Be Me).

Tỉnh thức - Osho: Căn nguyên của đau khổ và 4 bước để bạn tìm thấy phúc lạc

Từ sách - Phim - TĐ - 02/10/2025 08:00
Bạn không cần phải thích nghi với đau khổ; bạn có khả năng thoát khỏi đau khổ hoàn toàn. Nhưng con đường đó hơi gian nan; con đường đó là một thử thách. Bạn phải nhận thức được cơ thể của mình và những việc bạn đang làm với cơ thể...

Những dấu hiệu người dùng Facebook cần đổi mật khẩu ngay

Kỹ năng - Anh Quang - 01/10/2025 13:00
Tài khoản Facebook có thể bị xâm nhập mà bạn không hay biết – nhận diện sớm những dấu hiệu bất thường sẽ giúp bạn bảo vệ thông tin cá nhân kịp thời.

Xem "Sex Education", tôi quyết định trao quyền: Con thay đổi hẳn, không còn lấm lét giấu giếm

Điện ảnh - Ứng Hà Chi - 01/10/2025 12:00
Đây không chỉ là bộ phim về giới tính mà còn là lời nhắc cho các bậc phụ huynh trong giáo dục con đúng cách.

"Thành phố lăng mộ" tiền tỷ ở làng chài nghèo khó một thời

Thư giãn - Cao Tiến - DT - 01/10/2025 11:00
Làng An Bằng ở thành phố Huế vốn là vùng quê nghèo ven biển, người dân mưu sinh bằng nghề chài lưới, giờ đây được mệnh danh "thành phố lăng mộ" với nhiều công trình hàng tỷ đồng.

Lạm dụng AI đe dọa sự sáng tạo tri thức, gây ‘thoái hóa’ tư duy con người

Suy ngẫm - Băng Băng - 01/10/2025 10:00
Các nghiên cứu cho thấy sự phụ thuộc vào AI có thể đem lại những hệ lụy khôn lườ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ứ 6, 03/10/2025