Play Video
1
What is Software Maintenance
What is Software Maintenance
::2010/12/21::
Play Video
2
Knowledge Transfer in Software-Maintenance Offshore Outsourcing
Knowledge Transfer in Software-Maintenance Offshore Outsourcing
::2013/07/15::
Play Video
3
CMMS Computerized Maintenance Management System Benchmate
CMMS Computerized Maintenance Management System Benchmate
::2013/01/16::
Play Video
4
Basic PC Maintenance
Basic PC Maintenance
::2012/03/25::
Play Video
5
Pro Maintainer CMMS Preventive Maintenance
Pro Maintainer CMMS Preventive Maintenance
::2009/03/06::
Play Video
6
Software Maintenance: Making Software Maintainable
Software Maintenance: Making Software Maintainable
::2010/12/28::
Play Video
7
Hardware and Software Maintenance
Hardware and Software Maintenance
::2013/10/03::
Play Video
8
Quantum HD Software Maintenance
Quantum HD Software Maintenance
::2013/04/10::
Play Video
9
Software Maintenance and Reengineering Part 1 by Dr. Nedhal A. Al-Saiyd from ASU
Software Maintenance and Reengineering Part 1 by Dr. Nedhal A. Al-Saiyd from ASU
::2012/04/01::
Play Video
10
The Importance of Tracking Hardware & Software Maintenance Renewals
The Importance of Tracking Hardware & Software Maintenance Renewals
::2011/07/12::
Play Video
11
Computer maintenance software
Computer maintenance software
::2013/02/06::
Play Video
12
Truck Tracker Fleet Maintenance Software - Creating Work Orders (basic)
Truck Tracker Fleet Maintenance Software - Creating Work Orders (basic)
::2013/09/06::
Play Video
13
Software maintenance Process part3 By Dr Nedhal Al Saiyd .wmv
Software maintenance Process part3 By Dr Nedhal Al Saiyd .wmv
::2012/04/08::
Play Video
14
Productivity of Software Maintenance
Productivity of Software Maintenance
::2014/03/14::
Play Video
15
DB2 for z/OS Best Practice: Software Maintenance
DB2 for z/OS Best Practice: Software Maintenance
::2012/10/15::
Play Video
16
The Mobile Maintenance Manager by MPulse Software
The Mobile Maintenance Manager by MPulse Software
::2012/06/29::
Play Video
17
Challenging the Software Maintenance Status Quo
Challenging the Software Maintenance Status Quo
::2014/05/08::
Play Video
18
Using Evidence to Automate Software Maintenance - James A. Jones
Using Evidence to Automate Software Maintenance - James A. Jones
::2013/06/25::
Play Video
19
Rebel Rant
Rebel Rant's: Why Aren't You Taking Advantage of Your Software Maintenance Agreement?
::2014/06/16::
Play Video
20
Software Maintenance on Z/OS - Legacy process  vs  CA Chorus Software Manager
Software Maintenance on Z/OS - Legacy process vs CA Chorus Software Manager
::2013/06/20::
Play Video
21
DNC Software Wireless OEE Machine Monitoring Software Maintenance and Tool Management Software
DNC Software Wireless OEE Machine Monitoring Software Maintenance and Tool Management Software
::2014/07/16::
Play Video
22
TATEMS Fleet Maintenance Software Quick Demo-01
TATEMS Fleet Maintenance Software Quick Demo-01
::2012/08/10::
Play Video
23
ECE2012 - Assisting Software maintenance by connecting existing Source Code and Tasks
ECE2012 - Assisting Software maintenance by connecting existing Source Code and Tasks
::2012/12/06::
Play Video
24
A Visual Analysis Approach to Support Perfective Software Maintenance
A Visual Analysis Approach to Support Perfective Software Maintenance
::2012/06/25::
Play Video
25
Starting a Project: IT Software Maintenance
Starting a Project: IT Software Maintenance
::2011/06/11::
Play Video
26
TriStar Software Maintenance Demo
TriStar Software Maintenance Demo
::2013/04/10::
Play Video
27
The Benefits Of Software Maintenance Plans
The Benefits Of Software Maintenance Plans
::2008/06/11::
Play Video
28
Dr  Nedhal Al Saiyd   Software Maintenance and Reengineering   Part 2
Dr Nedhal Al Saiyd Software Maintenance and Reengineering Part 2
::2012/04/01::
Play Video
29
Smart Hotel Software Maintenance
Smart Hotel Software Maintenance
::2011/05/04::
Play Video
30
Software Maintenance and Reengineering- Part 5- By Dr Nedhal Al-Saiyd- ASU.wmv
Software Maintenance and Reengineering- Part 5- By Dr Nedhal Al-Saiyd- ASU.wmv
::2012/04/22::
Play Video
31
Automotive Wolf Car Maintenance Software - Configure Car Maintenance Schedule Demo
Automotive Wolf Car Maintenance Software - Configure Car Maintenance Schedule Demo
::2012/05/07::
Play Video
32
Introducing MAPCON Maintenance Software
Introducing MAPCON Maintenance Software
::2011/12/16::
Play Video
33
Software Maintenance and Reengineering  Part 6  By Dr Nedhal Al Saiyd  ASU
Software Maintenance and Reengineering Part 6 By Dr Nedhal Al Saiyd ASU
::2012/05/23::
Play Video
34
Maintenance Assistant CMMS - From Reactive to Proactive Maintenance
Maintenance Assistant CMMS - From Reactive to Proactive Maintenance
::2013/07/24::
Play Video
35
InnWinWin - Building Maintenance Management Software
InnWinWin - Building Maintenance Management Software
::2012/05/03::
Play Video
36
MEX Maintenance Software
MEX Maintenance Software
::2013/09/04::
Play Video
37
Technosoft Ltd Software Maintenance Management Expe EQUIPMENT MAINTENANCE
Technosoft Ltd Software Maintenance Management Expe EQUIPMENT MAINTENANCE
::2011/11/23::
Play Video
38
Asset Management software delivers great maintenance
Asset Management software delivers great maintenance
::2013/06/14::
Play Video
39
Preventative Maintenance Software from IQMS
Preventative Maintenance Software from IQMS
::2013/10/16::
Play Video
40
Yosemite Software Maintenance Plans
Yosemite Software Maintenance Plans
::2012/03/07::
Play Video
41
UiTM TAPAH-Software Maintenance 2013
UiTM TAPAH-Software Maintenance 2013
::2013/03/01::
Play Video
42
Simplilearn: Maintenance Testing | Software Testing Certification Workshop | CTFL Training
Simplilearn: Maintenance Testing | Software Testing Certification Workshop | CTFL Training
::2012/05/25::
Play Video
43
FROM ENGLISH TO GERMAN = Software maintenance and repair services
FROM ENGLISH TO GERMAN = Software maintenance and repair services
::2011/12/18::
Play Video
44
Hardware/Software Maintenance
Hardware/Software Maintenance
::2012/04/02::
Play Video
45
Aircraft Maintenance Systems Software Presentation
Aircraft Maintenance Systems Software Presentation
::2010/09/28::
Play Video
46
Software Tool Tip: Grouping Maintenance Tasks in BlockSim
Software Tool Tip: Grouping Maintenance Tasks in BlockSim
::2014/04/04::
Play Video
47
VOCABULARY IN 20 LANGUAGES = Software maintenance and repair services
VOCABULARY IN 20 LANGUAGES = Software maintenance and repair services
::2011/04/07::
Play Video
48
PC maintenance - 5 programs for maintaining windows
PC maintenance - 5 programs for maintaining windows
::2012/05/06::
Play Video
49
Building Software, Property Management Software, Property Software, Property Maintenance Software
Building Software, Property Management Software, Property Software, Property Maintenance Software
::2013/10/17::
Play Video
50
CMMS SOFTWARE SIMMPRO HOW TO # 3 PREVENTIVE MAINTENANCE
CMMS SOFTWARE SIMMPRO HOW TO # 3 PREVENTIVE MAINTENANCE
::2014/01/05::
NEXT >>
RESULTS [51 .. 101]
From Wikipedia, the free encyclopedia
Jump to: navigation, search
Software development process
Coding Shots Annual Plan high res-5.jpg
Core activities
Methodologies
Supporting disciplines
Tools

Software maintenance in software engineering is the modification of a software product after delivery to correct faults, to improve performance or other attributes.[1]

A common perception of maintenance is that it merely involves fixing defects. However, one study indicated that the majority, over 80%, of the maintenance effort is used for non-corrective actions.[2] This perception is perpetuated by users submitting problem reports that in reality are functionality enhancements to the system. More recent studies put the bug-fixing proportion closer to 21%.[3]

Software maintenance and evolution of systems was first addressed by Meir M. Lehman in 1969. Over a period of twenty years, his research led to the formulation of Lehman's Laws (Lehman 1997). Key findings of his research include that maintenance is really evolutionary development and that maintenance decisions are aided by understanding what happens to systems (and software) over time. Lehman demonstrated that systems continue to evolve over time. As they evolve, they grow more complex unless some action such as code refactoring is taken to reduce the complexity.

The key software maintenance issues are both managerial and technical. Key management issues are: alignment with customer priorities, staffing, which organization does maintenance, estimating costs. Key technical issues are: limited understanding, impact analysis, testing, maintainability measurement.

Software maintenance is a very broad activity that includes error correction, enhancements of capabilities, deletion of obsolete capabilities, and optimization. Because change is inevitable, mechanisms must be developed for evaluation, controlling and making modifications.

So any work done to change the software after it is in operation is considered to be maintenance work. The purpose is to preserve the value of software over the time. The value can be enhanced by expanding the customer base, meeting additional requirements, becoming easier to use, more efficient and employing newer technology. Maintenance may span for 20 years, whereas development may be 1-2 years.

Importance of software maintenance[edit]

In the late 1970s, a famous and widely cited survey study by Lientz and Swanson, exposed the very high fraction of life-cycle costs that were being expended on maintenance. They categorized maintenance activities into four classes:

  • Adaptive – modifying the system to cope with changes in the software environment (DBMS, OS) [4]
  • Perfective – implementing new or changed user requirements which concern functional enhancements to the software
  • Corrective – diagnosing and fixing errors, possibly ones found by users [4]
  • Preventive – increasing software maintainability or reliability to prevent problems in the future [4]

The survey showed that around 75% of the maintenance effort was on the first two types, and error correction consumed about 21%. Many subsequent studies suggest a similar magnitude of the problem. Studies show that contribution of end user is crucial during the new requirement data gathering and analysis. And this is the main cause of any problem during software evolution and maintenance. So software maintenance is important because it consumes a large part of the overall lifecycle costs and also the inability to change software quickly and reliably means that business opportunities are lost. [5] [6] [7]

Impact of key adjustment factors on maintenance (sorted in order of maximum positive impact)

Maintenance Factors Plus Range
Maintenance specialists 35%
High staff experience 34%
Table-driven variables and data 33%
Low complexity of base code 32%
Y2K and special search engines 30%
Code restructuring tools 29%
Re-engineering tools 27%
High level programming languages 25%
Reverse engineering tools 23%
Complexity analysis tools 20%
Defect tracking tools 20%
Y2K “mass update” specialists 20%
Automated change control tools 18%
Unpaid overtime 18%
Quality measurements 16%
Formal base code inspections 15%
Regression test libraries 15%
Excellent response time 12%
Annual training of > 10 days 12%
High management experience 12%
HELP desk automation 12%
No error prone modules 10%
On-line defect reporting 10%
Productivity measurements 8%
Excellent ease of use 7%
User satisfaction measurements 5%
High team morale 5%
Sum 503%

Not only are error-prone modules troublesome, but many other factors can degrade performance too. For example, very complex “spaghetti code” is quite difficult to maintain safely. A very common situation which often degrades performance is lack of suitable maintenance tools, such as defect tracking software, change management software, and test library software. Below describe some of the factors and the range of impact on software maintenance.

Impact of key adjustment factors on maintenance (sorted in order of maximum negative impact)

Maintenance Factors Minus Range
Error prone modules -50%
Embedded variables and data -45%
Staff inexperience -40%
High code complexity -30%
No Y2K of special search engines -28%
Manual change control methods -27%
Low level programming languages -25%
No defect tracking tools -24%
No Y2K “mass update” specialists -22%
Poor ease of use -18%
No quality measurements -18%
No maintenance specialists -18%
Poor response time -16%
No code inspections -15%
No regression test libraries -15%
No help desk automation -15%
No on-line defect reporting -12%
Management inexperience -15%
No code restructuring tools -10%
No annual training -10%
No reengineering tools -10%
No reverse-engineering tools -10%
No complexity analysis tools -10%
No productivity measurements -7%
Poor team morale -6%
No user satisfaction measurements -4%
No unpaid overtime 0%
Sum -500%

[8]

Software maintenance planning[edit]

An integral part of software is the maintenance one, which requires an accurate maintenance plan to be prepared during the software development. It should specify how users will request modifications or report problems. The budget should include resource and cost estimates. A new decision should be addressed for the developing of every new system feature and its quality objectives. The software maintenance, which can last for 5–6 years (or even decades) after the development process, calls for an effective plan which can address the scope of software maintenance, the tailoring of the post delivery/deployment process, the designation of who will provide maintenance, and an estimate of the life-cycle costs. The selection of proper enforcement of standards is the challenging task right from early stage of software engineering which has not got definite importance by the concerned stakeholders.

Software maintenance processes[edit]

This section describes the six software maintenance processes as:

  1. The implementation process contains software preparation and transition activities, such as the conception and creation of the maintenance plan; the preparation for handling problems identified during development; and the follow-up on product configuration management.
  2. The problem and modification analysis process, which is executed once the application has become the responsibility of the maintenance group. The maintenance programmer must analyze each request, confirm it (by reproducing the situation) and check its validity, investigate it and propose a solution, document the request and the solution proposal, and finally, obtain all the required authorizations to apply the modifications.
  3. The process considering the implementation of the modification itself.
  4. The process acceptance of the modification, by confirming the modified work with the individual who submitted the request in order to make sure the modification provided a solution.
  5. The migration process (platform migration, for example) is exceptional, and is not part of daily maintenance tasks. If the software must be ported to another platform without any change in functionality, this process will be used and a maintenance project team is likely to be assigned to this task.
  6. Finally, the last maintenance process, also an event which does not occur on a daily basis, is the retirement of a piece of software.

There are a number of processes, activities and practices that are unique to maintainers, for example:

  • Transition: a controlled and coordinated sequence of activities during which a system is transferred progressively from the developer to the maintainer;
  • Service Level Agreements (SLAs) and specialized (domain-specific) maintenance contracts negotiated by maintainers;
  • Modification Request and Problem Report Help Desk: a problem-handling process used by maintainers to prioritize, documents and route the requests they receive;

Categories of maintenance in ISO/IEC 14764[edit]

E.B. Swanson initially identified three categories of maintenance: corrective, adaptive, and perfective.[9] These have since been updated and ISO/IEC 14764 presents:

  • Corrective maintenance: Reactive modification of a software product performed after delivery to correct discovered problems.
  • Adaptive maintenance: Modification of a software product performed after delivery to keep a software product usable in a changed or changing environment.
  • Perfective maintenance: Modification of a software product after delivery to improve performance or maintainability.
  • Preventive maintenance: Modification of a software product after delivery to detect and correct latent faults in the software product before they become effective faults.

There is also a notion of pre-delivery/pre-release maintenance which is all the good things you do to lower the total cost of ownership of the software. Things like compliance with coding standards that includes software maintainability goals. The management of coupling and cohesion of the software. The attainment of software supportability goals (SAE JA1004, JA1005 and JA1006 for example). Note also that some academic institutions are carrying out research to quantify the cost to ongoing software maintenance due to the lack of resources such as design documents and system/software comprehension training and resources (multiply costs by approx. 1.5-2.0 where there is no design data available.).

See also[edit]

References[edit]

[10]

  1. ^ "ISO/IEC 14764:2006 Software Engineering — Software Life Cycle Processes — Maintenance". Iso.org. 2011-12-17. Retrieved 2013-12-02. 
  2. ^ Pigoski, Thomas M., 1997: Practical software maintenance: Best practices for managing your software investment. Wiley Computer Pub. (New York)
  3. ^ Eick, S., Graves, T., Karr, A., Marron, J., and Mockus, A. 2001. Does Code Decay? Assessing Evidence from Change Management Data. IEEE Transactions on Software Engineering. 27(1) 1-12.
  4. ^ a b c Software Maintenance and Re-engineering, CSE2305 Object-Oriented Software Engineering
  5. ^ Lientz B., Swanson E., 1980: Software Maintenance Management. Addison Wesley, Reading, MA
  6. ^ Lehman M. M., 1980: Program, Life-Cycles and the Laws of Software Evolution. In Proceedings of IEEE, 68, 9,1060-1076
  7. ^ Penny Grubb, Armstrong A. Takang, 2003: Software Maintenance: Concepts and Practice. World Scientific Publishing Company
  8. ^ "The Economics Of Software Maintenance In The Twenty First Century" (PDF). Retrieved 2013-12-02. 
  9. ^ "E. Burt Swanson, The dimensions of maintenance. Proceedings of the 2nd international conference on Software engineering, San Francisco, 1976, pp 492 — 497". Portal.acm.org. doi:10.1145/359511.359522. Retrieved 2013-12-02. 
  10. ^ Pigoski, Thomas. "Chapter 6: Software Maintenance". SWEBOK. IEEE. Retrieved 5 November 2012. 

Further reading[edit]

  • Pigoski, Thomas M. (1996). Practical Software Maintenance. New York: John Wiley & Sons. ISBN 978-0-471-17001-3. 
  • Pigoski, Thomas M. Description for Software Evolution and Maintenance (version 0.5). SWEBOK Knowledge Area. 
  • April, Alain; Abran, Alain (2008). Software Maintenance Management. New York: Wiley-IEEE. ISBN 978-0-470-14707-8. 
  • Gopalaswamy Ramesh; Ramesh Bhattiprolu (2006). Software maintenance : effective practices for geographically distributed environments. New Delhi: Tata McGraw-Hill. ISBN 978-0-07-048345-3. 
  • Grubb, Penny; Takang, Armstrong (2003). Software Maintenance. New Jersey: World Scientific Publishing. ISBN 978-981-238-425-6. 
  • Lehman, M.M.; Belady, L.A. (1985). Program evolution : processes of software change. London: Academic Press Inc. ISBN 0-12-442441-4. 
  • Page-Jones, Meilir (1980). The Practical Guide to Structured Systems Design. New York: Yourdon Press. ISBN 0-917072-17-0. 

External links[edit]

Wikipedia content is licensed under the GFDL License
Powered by YouTube
LEGAL
  • Mashpedia © 2014