DocumentCode :
1398415
Title :
Eliminating exception handling errors with dependability cases: a comparative, empirical study
Author :
Maxion, Roy A. ; Olszewski, Robert T.
Author_Institution :
Dept. of Comput. Sci., Carnegie Mellon Univ., Pittsburgh, PA, USA
Volume :
26
Issue :
9
fYear :
2000
fDate :
9/1/2000 12:00:00 AM
Firstpage :
888
Lastpage :
906
Abstract :
Programs fail mainly for two reasons: logic errors in the code and exception failures. Exception failures can account for up to two-thirds of system crashes, hence, are worthy of serious attention. Traditional approaches to reducing exception failures, such as code reviews, walkthroughs, and formal testing, while very useful, are limited in their ability to address a core problem: the programmer´s inadequate coverage of exceptional conditions. The problem of coverage might be rooted in cognitive factors that impede the mental generation (or recollection) of exception cases that would pertain in a particular situation, resulting in insufficient software robustness. This paper describes controlled experiments for testing the hypothesis that robustness for exception failures can be improved through the use of various coverage-enhancing techniques: N-version programming, group collaboration, and dependability cases. N-version programming and collaboration are well known. Dependability cases, derived from safety cases, comprise a new methodology based on structured taxonomies and memory aids for helping software designers think about and improve exception handling coverage. All three methods showed improvements over control conditions in increasing robustness to exception failures but dependability cases proved most efficacious in terms of balancing cost and effectiveness
Keywords :
exception handling; program debugging; software reliability; N-version programming; cognitive factors; cost effectiveness; coverage-enhancing techniques; dependability cases; exception failures; exception handling errors; experiments; group collaboration; logic errors; software designers; software reliability; software robustness; system crashes; Collaboration; Computer crashes; Impedance; Logic; Robust control; Robustness; Software design; Software safety; Taxonomy; Vehicle crash testing;
fLanguage :
English
Journal_Title :
Software Engineering, IEEE Transactions on
Publisher :
ieee
ISSN :
0098-5589
Type :
jour
DOI :
10.1109/32.877848
Filename :
877848
Link To Document :
بازگشت