24/05/2018, 23:14

Công cụ trợ giúp và phân loại

Mọi người đều biết sự đắt đỏ và các khó khăn của việc phát triển phần mềm. Việc cung cấp cho các kỹ sư phần mềm các công cụ trợ giúp, nó cung cấp khả năng tự động phát triển chương trình là rất hiệu quả về mặt chi phí. Trong thời đại nhiều máy móc như hiện ...

Mọi người đều biết sự đắt đỏ và các khó khăn của việc phát triển phần mềm. Việc cung cấp cho các kỹ sư phần mềm các công cụ trợ giúp, nó cung cấp khả năng tự động phát triển chương trình là rất hiệu quả về mặt chi phí. Trong thời đại nhiều máy móc như hiện nay, những trợ giúp phát triển thường có sẵn: môi trường CASE, sinh mã và những trợ giúp kiểm tra như gỡ rối, các chương trình biên dịch tăng, môi trường thực hiện theo kiểu cửa sổ và cả tốc độ phát triển mã hoạt động. Bất kỳ ngôn ngữ nào đều có sự trợ giúp tự động,

Như thế, một môi trường phát triển phần mềm là một bộ các công cụ phần cứng và phần mềm chúng được kết lại để trợ giúp cho việc sản sinh ra một hệ thống phần mềm trong một miền ứng dụng chuyên biệt.

CASE có các loại ICASE, Upper CASE và Lower CASE. ICASE nghĩa là

"Intergrated" CASE hay là CASE tích hợp, "Upper" nghĩa là công cụ ý tưởng hay chỉ là thiết kế logic, "Lower" nghĩa là công cụ chỉ hỗ trợ lập trình. Trong những công cụ trên, tài liệu này tập trung vào các công cụ CASE hỗ trợ tối thiểu một giai đoạn phân tích và có thể hỗ trợ các giai đoạn khác; chúng được gọi chung là "CASE". Chúng ta cũng xác định những giai đoạn hiện nay đang được hỗ trợ (dĩ nhiên là các giai đoạn này có thể thay đổi khi phát hành).

Môi trường CASE chuẩn bao gồm một kho chứa, các công cụ đồ hoạ, phần mềm soạn thảo văn bản, phần mềm giao diện kho chứa, phần mềm đánh giá, và giao diện người sử dụng.

Một kho chứa là một từ điển dữ liệu hỗ trợ định nghĩa về các kiểu đối tượng khác nhau và quan hệ giữa các đối tượng đó. Các công cụ đồ hoạ hỗ trợ cho việc phát triển dạng sơ đồ và đánh giá sự hoàn chỉnh của sơ đồ dựa vào các luật đã được xác định trước. Phần mềm văn bản cho phép định dạng tên, nội dung, và chi tiết các phần tử trong kho chứa. Phần mềm giao diện là bộ biên dịch xác định dạng dữ liệu được dùng (đồ hoạ hoặc văn bản). Phần mềm đánh giá là trí tuệ của CASE. Phần mềm này phân tích các đầu vào của sơ đồ hoặc kho chứa và xác định xem chúng có cú pháp hoàn chỉnh hay không (ví dụ có thoả mãn các định nghĩa của kiểu dữ liệu thành phần không), và chúng có tương thích với các đối tượng đang tồn tại khác trong ứng dụng hay không. Giao diện người dùng cung cấp các màn hình và các báo cáo để xử lý tương tác và gián tiếp.

CASE lý tưởng phải cung cấp đầy đủ hỗ trợ tự động cho toàn bộ chu kỳ tồn tại của dự án, bắt đầu bằng việc phân tích ở mức xí nghiệp, duy trì công việc và kết thúc. CASE lý tưởng do đó trở thành tiêu điểm cho mọi công việc nằm trong công nghệ phần mềm, và công việc của kỹ sư hệ thống tập trung vào khía cạnh logic của thiết kế. Công cụ CASE lý tưởng cũng có thể cung cấp về mặt kỹ thuật, dữ liệu và thực hiện thiết kế của tổ chức, lập dự án và kiểm tra nhóm làm việc trong các ứng dụng, chuẩn hoá dữ liệu, sơ đồ xây dựng cơ sở dữ liệu, xây dựng mã đơn giản bằng ngôn ngữ người sử dụng lựa chọn, tự động kiểm tra mã sinh ra đề phòng các lỗi logic và đánh giá sự hoàn chỉnh và đúng đắn trong quá trình làm việc một cách thông minh. Công cụ CASE thực hiện sự tiên tiến phải nhận ra các thành phần đã có trong kho chứa sử dụng lại việc phân tích, thiết kế và mã nguồn.

Kho chứa của CASE xác định đồng thời cái gì được hỗ trợ và trong phạm vi nào đó, có thể là hỗ trợ được bao nhiêu. Kho chứa là một siêu từ điển có thể nhập và lưu trữ siêu dữ liệu. Chẳng hạn, một phần tử dữ liệu trong một ứng dụng là dữ liệu, và các thuộc tính của nó tạo thành dữ liệu trao đổi có thể lưu trữ trong từ điển. Các thuộc tính của một phần tử bao gồm kiểu dữ liệu, kích thước, dung lượng, tần suất thay đổi và tiêu chuẩn soạn thảo. Một kho chứa CASE hoạt động như là một hệ quản trị cơ sở dữ liệu phục vụ cho hoạt động kỹ sư, cung cấp khả năng mở rộng lưu giữ dữ liệu trao đổi, và duy trì tất cả các thành phần và mối liên hệ qua lại giữa chúng.

Sự thông minh trong CASE thể hiện ở hai dạng chính: thông minh của giao diện và thông minh của bản thân sản phẩm CASE. Giao diện phải cung cấp cả kiểu thao tác cho người mới tập sự và cho người đã có kinh nghiệm. Nó phải cho phép khả năng một công việc được lưu giữ và tiếp tục lại. Công cụ này có thể được thay đổi theo yêu cầu cá nhân của người sử dụng. Ví dụ, nếu tôi muốn in màu vàng trên nền xanh, tôi sẽ gọi một lược đồ dòng dữ liệu, và tôi phải được phép thay đổi giá trị ngầm định để dùng các thuật ngữ và dạng của mình.

Các dạng biến đổi các giá trị đưa vào phải được phản ánh thông qua các tập sơ đồ. Điều này có nghĩa là nếu người dùng đưa các thực thể và các thuộc tính vào một kho chứa, khi anh ta di chuyển để triển khai một lược đồ đồ hoạ quan hệ thực thể, thông tin trong kho chứa phải được phản ánh trên lược đồ.

Trí tuệ của sản phẩm CASE bao gồm việc phân tích bên trong và giữa các kiểu lược đồ và đầu vào kho chứa. Trong trường hợp lý tưởng, yêu cầu của ứng dụng A nếu

xung đột với mục tiêu của xí nghiệp Z, sẽ phải được bật cờ báo để xem ý kiến của người quản lý.

CASE lý tưởng phải cho phép người sử dụng phân tách và tích hợp các ứng dụng khác nhau một cách dễ dàng. Ví dụ, một công ty có thể muốn tư liệu hoá tất cả ứng dụng đã sử dụng và bắt đầu quản lý điện tử chúng. Khi người sử dụng xác định một ứng dụng mới có thể muốn tích hợp nó với một ứng dụng cũ, họ phải được phép để tạo ra một định nghĩa thứ ba để làm sáng tỏ sự chồng chéo, dư thừa, không chắc chắn và các vấn đề khác mà cặp tích hợp gặp phải.

Theo quy luật 40-20-40 của việc triển khai hệ thống, 40% thời gian của dự án được dùng để phân tích và thiết kế, 20% dành cho lập trình và 40% còn lại để chạy thử. Hướng hiện tại của các nhà bán sản phẩm là giảm bớt mã, do đó giảm đi 20% thời gian phát triển. Nhưng CASE lý tưởng sẽ còn có thể giảm được 40% thời gian chạy thử. Các công cụ kiểm tra CASE không cần thiết bằng các vấn đề khác (chẳng hạn cho sản phẩm làm việc tự do lỗi).

Trong một số sản phẩm ở thập kỷ 90, các nhà sản xuất sẽ cung cấp hỗ trợ kiểm tra trong các môi trường CASE của họ. Một cách lý tưởng, những hỗ trợ như vậy sẽ bao gồm cả thử nghiệm hộp đen và hộp trắng cùng với can thiệp của con người, nhưng không bắt buộc. Thử nghiệm hộp đen dùng cho kiểm tra sự kiểm tra chính xác của đầu ra dựa trên đầu vào; trong khi đó thử nghiệm hộp trắng dùng cho các sơ đồ logic trong chương trình. Phần mềm thông minh sẽ phân tích kiểu thực hiện và xác định chiến lược thử nghiệm thích hợp nhất. Thêm vào đó, nó sẽ phát triển dữ liệu thử nghiệm dựa trên các yêu cầu logic, dẫn dắt thử nghiệm và duy trì các kết quả thử nghiệm. Các kết quả thử nghiệm sẽ được tổng hợp thông qua chạy thử, các giai đoạn thử nghiệm, phiên bản phần mềm, và ngay cả các môi trường phần cứng. Khi lỗi được tìm ra, phần mềm này sẽ quay lại chỉnh tìm nguồn gốc lỗi - có khả năng là thông qua các module.

Khi phần mềm tạo nên lỗi phải có khả năng sửa chúng; nhưng nếu gây ra lỗi là một người hay là một lỗi logic, phần mềm phải thông báo cho kỹ sư hệ thống yêu cầu sửa lỗi.

Các sản phẩm trong tương lai này sẽ thực sự khắc phục 40% thời gian của dự án do chúng đủ thông minh để xác định các thành phần có thể sử dụng lại được của ứng dụng. Việc sử dụng lại thiết kế sẽ tiết kiệm được nhiều nhất nhưng cũng là việc khó khăn nhất. Đầu tiên, các module mã sẽ được sử dụng lại, sau đó đến lượt thiết kế, cuối cùng là phân tích logic cũng được dùng lại. Việc tìm ra mã có thể sử dụng lại được các công cụ CASE cung cấp vào giữa những năm 90, các phần khác sẽ được cung cấp vào thế kỷ này.

Việc miêu tả tính chất của CASE lý tưởng tập trung vào việc xem CASE có thể làm gì tốt hơn hiện tại. Với vấn đề này, chúng ta sẽ nghiên cứu CASE mỗi khi nó hỗ trợ một phương pháp luận và phát triển trong các chương sau. Mặc dù CASE và trí tuệ nhân tạo đang còn rất non trẻ, nhưng sự phát triển được mô tả ở trên hiện tại đã có thể thực hiện được với hiện trạng kỹ thuật công nghệ thế giới. Kho chứa CASE sẽ trở thành một trung tâm cho mọi công việc hoạt động trong các tổ chức hệ thống thông tin. Trí tuệ của CASE sẽ là chính trí tuệ của con người.

Các cấp độ tổ hợp CASE có thể phân loại. Tại mức thấp nhất của phổ tích hợp là các công cụ đơn. Khi các công cụ riêng lẻ cung cấp các tiện ích về truyền dữ liệu mức độ tích hợp đã có đôi chút cải thiện. Các công cụ như vậy sản xuất các đầu ra theo dạng chuẩn có thể tương thích với các công cụ khác có thể đọc format này. Trong một số trường hợp, các người xây dựng các công cụ CASE hoàn chỉnh làm việc với nhau thông qua "cầu nối" giữa các tools. Single- source intergration xuất hiện khi các nhà sản xuất công cụ CASE đơn lẻ tích hợp một số lượng công cụ khác nhau và bán chúng như là một gói phần mềm.

Mức độ tích hợp cao nhất có (IPSE) Intergrated Project Support Environment. Các chuẩn cho mỗi khối cấu thành được mô tả trên được tạo. Các nhà sản xuất công cụ CASE sử dụng các chuẩn IPSE này để xây dựng các công cụ tương thích với các nhà sản xuất khác theo chuẩn.

Các công cụ lập kế hoạch hệ thống tác nghiệp

Bằng cách mô hình hoá các yêu cầu thông tin chiến lược của tổ chức, công cụ lập kế hoạch hệ thống tác nghiệp (Business System Planning Tools) cung cấp một siêu mô hình mà từ đó hệ thống thông tin đặc trưng sẽ được suy ra. Các thông tin tác nghiệp được mô hình hoá khi nó chuyển từ các thực thể được tổ chức khác nhau trong công ty. Mục đích chính của các công cụ trong phân loại là giúp hiểu biết được thông tin di chuyển giữa các đơn vị tổ chức như thế nào.

Các công cụ như vậy cung cấp nội dung quan trọng khi các chiến lược hệ thống thông tin được cấu trúc và khi các hệ thống và phương pháp hiện tại không hợp với yêu cầu của tổ chức.

Các công cụ quản lý dự án

Nhiều nhà quản lý dự án phần mềm đang tiếp tục đánh giá, điều khiển và theo dõi các dự án phần mềm theo cách trước đây đã làm từ 1950. Mỉa mai thay, có một dãy rộng các công cụ quản lý dự án CASE có tác động sâu sắc lên chất lượng của quản lý dự án cho các cố gắng phát triển phần mềm cỡ lớn và nhỏ.

Hiện nay, phần lớn các công cụ quản lý dự án CASE định hướng vào một phần đặc trưng của quản lý dự án hơn là cung cấp hỗ trợ toàn bộ cho hoạt động quản lý. Bằng cách sử dụng một tập hợp công cụ CASE có chọn lọc, quản trị dự án có thể tạo ra các đánh giá hiệu quả về giá thành, nguồn lực, và thời gian của dự án phần mềm, xác định các cấu trúc công việc và thời biểu làm việc đồng thời theo dõi dự án. Hơn nữa người quản lý có thể sử dụng các công cụ để thu thập các metrics mà cuối cùng cung cấp các chỉ định về chất lượng và hiệu quả phát triển phần mềm.

Công cụ lập kế hoch dự án: Các công cụ trong lớp này tập trung vào hai mảng chính: định lượng giá, nguồn lực dự án và lập biểu dự án. Các công cụ định lượng giá thành cho phép quản trị dự án ước lượng cỡ của dự án bằng cách dùng các độ đo gián tiếp (số dòng mã và số các chức năng) và mô tả toàn bộ các đặc tính dự án (ví dụ độ

phức tạp, kinh nghiệm của đội ngũ). Các công cụ này tiếp theo ước lượng nguồn lực, thời gian dự án và gợi ý số lượng người. Nhiều công cụ trong số đó cho phép mô phỏng tình huống để quản trị có thể đã định thời gian hoàn thành và kiểm tra giá thành và khả năng thực hiện.

Các công cụ lập biểu dự án cho phép nhà quản lý xác định mọi nhiệm vụ, tạo mạng các công việc, biểu diễn sự phụ thuộc công việc. Phần lớn các công cụ sử dụng phương pháp lập đoạn gắng để xác định thời lượng hoàn thành dự án.

Cáccôngcụtheodõicácyêucầu:Khi hệ thống được phát triển lớn dần thì rất có nguy cơ rơi vào tình trạng đổ vỡ, hệ thống đã hoàn thiện không đáp ứng hoàn toàn các yêu cầu của khách hàng. Mục đích của các công cụ theo dõi yêu cầu là cung cấp một cách tiếp cận hệ thống để phân tách các yêu cầu, bắt đầu với các quy trình gội thầu -RFP (Request For Proposal)- của khách hàng hoặc các đặc tả.

Công cụ theo dõi yêu cầu đặc trưng bao gồm các định lượng text giao tác người-máy, cùng với hệ thống quản lý cơ sở dữ liệu lưu trữ và phân loại các yêu cầu hệ thống mà chuyển đến từ các RFP hoặc các đặc tả. Phân tích viên phân loại các yêu cầu được biểu diễn bởi các câu và đưa chúng vào cơ sở dữ liệu.

Các công cụ quản lý và độ đo: Các độ đo phần mềm cải thiện khả năng của nhà quản lý để điều khiển và phối hợp quá trình xử lý sản xuất phần mềm và khả năng của các cộng tác viên để cải thiện chất lượng phần mềm. Các công cụ đánh giá hoặc độ đo hiện nay tập trung vào các đặc trưng xử lý và chế tạo. Các công cụ định hướng quản lý thu thập các độ đo đặc trưng dự án. Các công cụ định lượng kỹ thuật xác định các độ đo kỹ thuật. Cung cấp các điểm quan trọng nhất về chất lượng thiết kế hoặc mã.

Các công cụ quản lý hỗ trợ cho nhà quản lý hệ thống thông tin cho phép ưu tiên các dự án có sự cạnh tranh về các nguồn tài nguyên hữu hạn. Do sử dụng các yêu cầu, độ ưu tiên, các ràng buộc được đặt trong các tổ chức và các lỗi, rũi ro của kỹ thuật và nghiệp vụ, những công cụ này sử dụng các kiến thức chuyên gia để đưa ra các gợi ý quyết định cho nhà quản lý.

Các công cụ hỗ trợ

Các công cụ tư liệu hoá cho phép cán bộ phát triển ứng dụng tự động hoá cập nhật tài liệu và in các báo cáo về ứng dụng.

Các công cụ phân tích và thiết kế

Các công cụ phân tích và thiết kế cho phép các kỹ sư phần mềm tạo các mô hình của hệ thống. Nó bao gồm biểu diễn cho dữ liệu, luồng điều khiển, nội dung dữ liệu (thông qua các đinh nghĩa từ điển các yêu cầu), quá trình xử lý, các đặc tả điều khiển, và các biểu diễn mô hình hoá khác.

Các công cụ phân tích và thiết kế hỗ trợ cả việc tạo mô hình cũng như đánh giá chất lượng. Bằng quá trình kiểm tra tính chắc chắn và giá trị của mô hình, các công cụ phân tích và thiết kế cung cấp cho công nghệ phần mềm khả năng giảm tối thiểu các lỗi có khả năng lan truyền tới chương trình ứng dụng.

CôngcSA/SD:Phần lớn các công cụ phân tích và thiết kế sử dụng phương pháp phân tích và thiết kế cấu trúc. Nó cho phép tạo các mô hình của hệ thống phức tạp dần, bắt đầu từ mức độ yêu cầu và kết thúc với sơ đồ kiến trúc.

Công cụ PRO/SIM: Các công ty tạo mẫu và mô phỏng (Prototyping and simulation) cho khả năng dự đoán trước dáng điệu của hệ thống. Mặt khác, nó cho phép khách hàng trong thời gian ngắn nhất có thể quan sát được mô hình. Nhiều công cụ dạng này cho phép sản sinh mã.

Cáccôngcụpháttriểnthiếtkếgiaodiện:Các nghiên cứu công nghiệp cho thấy rằng 50-80% mã của các ứng dụng tương tác là dành cho quản lý giao diện. Các công cụ phát triển và thiết kế giao diện thực sự là tập hợp các công cụ tạo các đơn vị chương trình như menu, button, windows,...Tuy nhiên, các công cụ trên đang được thay thế bởi các công cụ tạo mẫu giao diện cho phép tạo các màn hình theo chuẩn một cách nhanh chóng.

Các công cụ lập trình

Các công cụ lập trình bao gồm bộ dịch, soạn thảo, gỡ lỗi cho phép dùng phần lớn các ngôn ngữ lập trình truyền thống. Các công cụ này có liên quan nhiều tới môi trường lập trình hướng đối tượng, ngôn ngữ thế hệ bốn, sản sinh chương trình.

Cáccôngcụhoátruyềnthống:Đã có thời các công cụ mã hoá quy ước là: Complier, Editor, Debugger. Pressman đã nói về vấn đề này như sau: "Khi trong tay bạn chỉ có cái búa, thì mọi vấn đề sẽ giống như cái đinh". Hầu như suốt 30 năm, lập trình viên chỉ có các công cụ trên trong tay nên mọi vấn đề về công nghệ phần mềm đều quy về vấn đề mã hoá.

Cáccôngcụmãhoáthếhệ4:Hệ thống hỏi đáp cơ sở dữ liệu, sinh mã và ngôn ngữ thế hệ 4 đã làm thay đổi cách lập trình.

Các công cụ lập trình hướng đối tượng: Lập trình hướng đối tượng là một trong các công nghệ "nóng nhất" trong công nghệ phần mềm. Vì lý do này, các nhà chế tạo CASE đang cung cấp ồ ạt các công cụ phát triển phần mềm hướng đối tượng tới thị trường.

Các ngôn ngữ phổ biến hiện nay là C++, Eiffel, Smalltalk, Objective-C. Môi trường hướng đối tượng đặc trưng thường kết hợp với các cung cấp giao diện thế hệ 3

(menu, mouse, multitasking,...) cùng với các chức năng đặc biệt như "browser" - một chức năng cho phép kỹ sư phần mềm kiểm tra tất cả các đối tượng được chứa trong thư viện.

Có ba hạng công cụ kiểm tra được sử dụng nhiều nhất. Nhiều công cụ phải trải hết 2 hoặc 3 phân loại nói trên.

Các công cụ phân tích tĩnh:Các công cụ kiểm tra tĩnh giúp các kỹ sư phần mềm trong việc rút ra các trường hợp kiểm tra. Ba kiểu khác nhau của các công cụ kiểm tra tĩnh được dùng trong công nghiệp: các công cụ kiểm tra dựa trên mã, các ngôn ngữ kiểm tra đặc tả và các công cụ kiểm tra dựa trên yêu cầu.

Code-Based testing tools nhận mã nguồn như là đầu vào và tiến hành một số phân tích. Căn cứ vào mô tả của đầu vào chương trình và thiết kế thủ tục như là chỉ dẫn các công cụ kiểm tra tĩnh suy ra các trường hợp kiểm tra sử dụng đường dẫn, các kiểm tra điều kiện và các tiêu chuẩn luồng dữ liệu.

Requirements-based testing tools phân tách các yêu cầu người dùng và khuyên một số trường hợp kiểm tra (hoặc lớp kiểm tra) mà sẽ thử các yêu cầu. Để thực hiện tốt thì các công cụ trong phân hạng này phải truy nhập tới các đặc tả hình thức của phần mềm.

Specialized testing languages cho phép các kỹ sư phần mềm viết các đặc tả kiểm tra chi tiết mà mô tả mỗi trường hợp kiểm tra và logic cho sự thực hiện nó. Trong

phần lớn các trường hợp, các công cụ kiểm tra tĩnh sẽ tư liệu hoá và phân loại các phép kiểm tra. Và nó sẽ so sánh kết quả thực với kết quả dự tính.

Các công cụ phân tích động: Các công cụ kiểm tra động tương tác với quá trình thực hiện chương trình, kiểm tra đường thử, kiểm tra xác nhận về giá trị các biến, các công cụ động có thể là loại can thiệp hoặc không can thiệp. Công cụ can thiệp

(intrusive) thay đổi phần mềm để kiểm tra. Công cụ không can thiệp (nointrusive) sử dụng một xử lý phần cứng tách rời chạy song song với xử lý chưa có chương trình đang kiểm tra. Phần lớn các công cụ thuộc phân loại phân tích động tạo các báo cáo chỉ rõ số lượng các khối, câu lệnh đã được thực hiện và các thời gian thực hiện trung bình cho các khối lệnh. Công cụ kiểm tra động có thể được dùng để nối tiếp với công cụ kiểm tra tĩnh. Các kiểm tra tĩnh tạo ra các trường hợp test sau đó được quản lý bởi các công cụ động.

Côngcquảntest:Công cụ quản lý test dùng để điều khiển và phối hợp các kiểm tra phần mềm cho mỗi bước kiểm tra chính. Các công cụ trong phân loại này quản lý và phối hợp các kiểm tra regression. Tiến hành các so sánh output thực và biểu kiến. Nhiều công cụ quản lý test cũng phục vụ như là các bộ điều khiển test.

Một bộ điều khiển test đọc một hoặc nhiều trường hợp test từ file test, định dạng các dữ liệu test để phù hợp nhu cầu phần mềm, sau đó gọi phần mềm để test. Cuối cùng, nhà quản lý test đôi khi làm việc với công cụ theo dõi yêu cầu để cung cấp các phân tích coverage yêu cầu cho kiểm tra.

Tạo mẫu được dùng rộng rãi như là sự tiến hoá của công nghệ phần mềm. Mức thấp nhất, các công cụ tạo "mẫu trên giấy". Công cụ chạy trên máy có thể tạo các hình ảnh thực dùng để minh hoạ các chức năng, dáng điệu hệ thống. Các hình ảnh này không thể thực hiện được. Trong một số trường hợp, bộ vẽ màn hình có thể sinh ra các mã để tạo màn hình. Các công cụ CASE phức tạp hơn cho phép tạo các thiết kế dữ liệu, cả màn hình hiển thị và báo biểu.

Các công cụ bảo trì có thể được phân lại theo các chức năng sau:

+ Thiết kế ngược với các công cụ đặc trưng.

+ Các công cụ phân tích và cấu trúc lại mã.

+ Các công cụ kiến tạo lại hệ thống trực tuyến.

Cáccôngcụthiếtkếngược:Các công cụ thiết kế ngược tiến hành tạo lại các phân tích ban đầu trên cơ sở các chương trình đã tồn tại. Các công cụ này cũng có thể phân ra loại tĩnh và động.

Một công cụ thiết kế ngược dùng mã nguồn như đầu vào và phân tích lấy ra kiến trúc chương trình, cấu trúc điều khiển, luồng logic, cấu trúc dữ liệu, luồng dữ liệu. Các công cụ thiết kế phụ thuộc (Dependency analysis tools) tiến hành phần lớn các chức năng trên, ngoài ra nó còn xây dựng sơ đồ graphic biểu diễn sự phụ thuộc chỉ sự liên kết giữa các cấu trúc dữ liệu, khối chương trình, và các đặc tính khác của chương trình.

Các công cụ thiết kế ngược quan sát phần mềm khi nó chạy và sử dụng các thông tin nhận được để xây dựng mô hình dáng điệu của chương trình. Mặc dù chúng ít được dùng nhưng cần thiết cho việc bảo trì các chương trình thời gian thực hoặc được nhúng trong hệ thống khác.

Cáccôngcụthiếtkế:Các công cụ thiết kế lại có thể chia làm hai nhóm: công cụ cấu trúc lại mã, công cụ thiết kế lại dữ liệu.

Các công cụ cấu trúc mã lại nhận mã nguồn phi cấu trúc như là đầu vào, tạo thiết kế ngược, sau đó cấu trúc lại mã mới. Mặc dù các công cụ như vậy có thể hữu ích, chúng chỉ tập trung trong việc thiết kế thủ tục của chương trình.

Các công cụ thiết kế lại dữ liệu làm việc tại cực kia của thiết kế. Các công cụ như vậy truy nhập định nghĩa dữ liệu hoặc cơ sở dữ liệu được mô tả trong ngôn ngữ lập trình hoặc ngôn ngữ mô tả cơ sở dữ liệu. Sau đó nó chuyển sang dạng biểu diễn graphic có thể phân tích được bởi kỹ sư phần mềm.

Tương tác với các công cụ thiết kế lại, kỹ sư phần mềm có thể thay đổi cấu trúc của cơ sở dữ liệu, chuẩn hoá dữ liệu, sau đó tự động sinh mã mới. Các công cụ có thể sử dụng hệ chuyên gia.

Các tiện ích CASE được xây dựng trên việc sinh mã hay các giao diện phục vụ cho sinh mã, cho phép trộn lẫn các mã khác nhau để phù hợp với môi trường phát triển và ngôn ngữ sinh ra.

Những tiện ích trên cung cấp một cách tự động bao gồm các tiện ích sinh mã, chương trình biên dịch lớn dần và môi trường tạo ra chương trình. Toàn bộ chúng chính là tiện ích Lower CASE hay Back-End CASE.

0