<< Chapter < Page Chapter >> Page >

Finally, at the highest level, the maintenance organization will have to conduct business planning activities (budgetary, financial, and human resources) just like all the other divisions of the organization.

Software configuration management

The IEEE Standard for Software Maintenance, IEEE 1219, describes software configuration management as a critical element of the maintenance process. Software configuration management procedures should provide for the verification, validation, and audit of each step required to identify, authorize, implement, and release the software product.

It is not sufficient to simply track Modification Requests or Problem Reports. The software product and any changes made to it must be controlled. This control is established by implementing and enforcing an approved software configuration management (SCM) process. SCM for software maintenance is different from SCM for software development in the number of small changes that must be controlled on operational software. The SCM process is implemented by developing and following a configuration management plan and operating procedures. Maintainers participate in Configuration Control Boards to determine the content of the next release/version.

Software quality

It is not sufficient, either, to simply hope that increased quality will result from the maintenance of software. It must be planned and processes implemented to support the maintenance process. The activities and techniques for Software Quality Assurance (SQA), V&V, reviews, and audits must be selected in concert with all the other processes to achieve the desired level of quality. It is also recommended that the maintainer adapt the software development processes, techniques and deliverables, for instance testing documentation, and test results.

Techniques for maintenance

This subarea introduces some of the generally accepted techniques used in software maintenance.

Program comprehension

Programmers spend considerable time in reading and understanding programs in order to implement changes. Code browsers are key tools for program comprehension. Clear and concise documentation can aid in program comprehension.

Reengineering

Reengineering is defined as the examination and alteration of software to reconstitute it in a new form, and includes the subsequent implementation of the new form. Dorfman and Thayer state that reengineering is the most radical (and expensive) form of alteration. Others believe that reengineering can be used for minor changes. It is often not undertaken to improve maintainability, but to replace aging legacy software. Arnold provides a comprehensive compendium of topics, for example: concepts, tools and techniques, case studies, and risks and benefits associated with reengineering.

Reverse engineering

Reverse engineering is the process of analyzing software to identify the software’s components and their interrelationships and to create representations of the software in another form or at higher levels of abstraction. Reverse engineering is passive; it does not change the software, or result in new software. Reverse engineering efforts produce call graphs and control flow graphs from source code. One type of reverse engineering is redocumentation. Another type is design recovery. Refactoring is program transformation which reorganizes a program without changing its behavior, and is a form of reverse engineering that seeks to improve program structure.

Questions & Answers

what is cell
Oppicial Reply
To know how bones are functions
DAUDA Reply
diagram of the heart
Victoria Reply
what are the layers of the muscles
Tongdock Reply
What is Amebae
Najibu Reply
the collection of fluids in the throat is cause by what
Emmanuel Reply
what is difference between meiosis and mitosis
Aishetu Reply
what is difference between mitosis and meiosis
Aishetu
What is Anatomy
Najibu Reply
What the difference between the Anatomy and physiology
Najibu
What is the meaning of chromoprotein
Aisha Reply
what is cartilage
Abdulkadir Reply
tough , white fibrous tissue
Henry
distinguish between anatomy and physiology
Amina Reply
Anatomy is the study of internal structure of an organism while physiology is the study of the function/relationship of the body organs working together as a system in an organism.
adeyeye
distinguish between anatomy and physiology
Erny Reply
regional anatomy is the study of the body regionally
Ismail Reply
what is the meaning of regional anatomy
Aminat Reply
epithelial tissue: it covers the Hollow organs and body cavities
Esomchi Reply
Got questions? Join the online conversation and get instant answers!
Jobilize.com Reply

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Software engineering. OpenStax CNX. Jul 29, 2009 Download for free at http://cnx.org/content/col10790/1.1
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Software engineering' conversation and receive update notifications?

Ask