2.1 Program Defects and "Bugs

Slides:



Advertisements
Similar presentations
Exception Handling The purpose of exception handling is to permit the program to catch and handle errors rather than letting the error occur and suffer.
Advertisements

C++ Programming: Program Design Including Data Structures, Fourth Edition Chapter 15: Exception Handling.
 2006 Pearson Education, Inc. All rights reserved. Exception Handling in C++ CS-2303, C-Term Exception Handling in C++ CS-2303 System Programming.
Ch 11. Exception Handling Timothy Budd Oregon State University.
Chapter 16: Exception Handling C++ Programming: From Problem Analysis to Program Design, Fifth Edition.
Objectives In this chapter you will: Learn what an exception is Learn how to handle exceptions within a program See how a try / catch block is used to.
Nirmalya Roy School of Electrical Engineering and Computer Science Washington State University Cpt S 122 – Data Structures Exception Handling: A Deeper.
C++ Programming: From Problem Analysis to Program Design, Third Edition Chapter 16: Exception Handling.
Monday, Mar 24, 2003Kate Gregory with material from Deitel and Deitel Week 11 Exceptions.
Jerry Lebowitz. Topics  Provides a facility for a systematic object oriented approach to handling runtime errors ◦ Can also handle runtime errors.
C++ Exception Handling
Rossella Lau Lecture 9, DCO10105, Semester B, DCO10105 Object-Oriented Programming and Design  Lecture 9: Application with Exception Handling 
CPSC 252 Exception Handling Page 1 Exceptions and exception handling Client programmers can make errors using a class attempting to dequeue an item from.
C++ Exceptions STL Vector. Example int Quotient (int numer, int denom} { if (denom != 0) return (numer/denom); else //What to do?? }
UNIT 3 TEMPLATE AND EXCEPTION HANDLING. Introduction  Program errors are also referred to as program bugs.  A C program may have one or more of four.
CMSC 202 Exceptions. Aug 7, Error Handling In the ideal world, all errors would occur when your code is compiled. That won’t happen. Errors which.
Introduction to Exception Handling and Defensive Programming.
Chapter 14: Exception Handling. Objectives In this chapter, you will: – Learn what an exception is – Learn how to handle exceptions within a program –
HANDLING EXCEPTIONS Chapter 9. Outline  Learn about the limitations of traditional error-handling methods  Throw exceptions  Use try blocks  Catch.
CSE 332: C++ Statements C++ Statements In C++ statements are basic units of execution –Each ends with ; (can use expressions to compute values) –Statements.
Chapter 15: Exception Handling C++ Programming: Program Design Including Data Structures, Fifth Edition.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 23 - Exception Handling Outline 23.1Introduction.
Exception Handling in C++. Outline What exceptions are and when to use them Using try, catch and throw to detect, handle and indicate exceptions, respectively.
CS212: Object Oriented Analysis and Design Lecture 19: Exception Handling.
Programming & Debugging. Key Programming Issues Modularity Modifiability Ease of Use Fail-safe programming Style Debugging.
Friend classes Friend class methods Nested classes Throwing exceptions, try blocks and catch blocks Exception classes Runtime type identification (RTTI)
C++ Namespaces, Exceptions CSci 588: Data Structures, Algorithms and Software Design All material not from online sources copyright © Travis Desell, 2011.
CHAPTER 18 C – C++ Section 1: Exceptions. Error Handling with Exceptions Forces you to defend yourself Separates error handling code from the source.
CSE 332: C++ Exceptions Motivation for C++ Exceptions Void Number:: operator/= (const double denom) { if (denom == 0.0) { // what to do here? } m_value.
Bill Tucker Austin Community College COSC 1315
C ++ MULTIPLE CHOICE QUESTION
Exception handling.
Exception Handling in C++
IS 0020 Program Design and Software Tools
Chapter 16 Exception Handling
Abstract Class Abstract Class is a class which contains atleast one Pure Virtual function in it. Abstract classes are used to provide an Interface for.
Exceptions Exceptions are used to signal that an unexpected event has happened in a program C++ will generate exceptions for some errors in the program.
CS212: Object Oriented Analysis and Design
Exceptions.
CMSC202 Computer Science II for Majors Lecture 16 – Exceptions
Chapter 6 CS 3370 – C++ Functions.
Testing and Debugging.
Why exception handling in C++?
Friday, January 26, 2018 Announcements… For Today… For Next Time…
EXCEPTION HANDLING.
Wednesday, January 31, 2018 Announcements… For Today… For Next Time…
Chapter 14: Exception Handling
Chapter 2 part #3 C++ Input / Output
2.3 Testing Programs 12 – Program Correctness.
3.3 Abstract Classes, Assignment, and Casting in a Hierarchy
Exceptions with Functions
Chapter 17 Templates and Exceptions Part 2
Throwing exceptions.
Part B – Structured Exception Handling
Throwing exceptions.
CSC 270 – Survey of Programming Languages
Exceptions 1 CMSC 202.
Program Correctness and Efficiency
CISC/CMPE320 - Prof. McLeod
CISC/CMPE320 - Prof. McLeod
2.5 Reasoning about Programs: Assertions and Loop Invariants
Today’s Objectives 10-Jul-2006 Announcements Quiz #3
2.1 Program Defects and "Bugs''
Chapter 1 c++ structure C++ Input / Output
CMSC 202 Exceptions.
Exception Handling.
ENERGY 211 / CME 211 Lecture 24 November 14, 2008.
CMSC 202 Lesson 20 Exceptions 1.
2.6, pgs Efficiency of Algorithms Big-O Notation
2.1-5, pgs Program Defects and "Bugs'' 2.2 Exceptions
Presentation transcript:

2.1 Program Defects and "Bugs 2.2 Exceptions 11 – Program Correctness

Attendance Quiz #9 Program Correctness

Tip #11: Virtual Functions Program Correctness Polymorphism refers to the ability to associate many meanings to one function name by means of a special mechanism known as virtual functions or late binding. There are clear advantages to using virtual functions, so, why not make all member functions virtual? The answer: There is a large overhead to making a function virtual. class Instrument virtual void play() {} class Wind : public Instrument class Percussion : public Instrument ... vector<Instrument*> instruments; instruments.push_back(new Wind()); instruments.push_back(new Percussion()); for (size_t i; i < instruments.size(); ++i) instruments[i]->play(); It uses more storage and makes your program run slower than if the function were not virtual. That is why the designers of C++ gave the programmer control over which member functions are virtual and which are not. If you expect to need the advantages of a virtual member function, then by all means, make that member function virtual. If you do not expect to need the advantages of a virtual function, then your program will run more efficiently if you do not make the member function virtual.

Follow-up… Program Correctness #include <iostream> #include <vector> #include <string> #include "shape.h" #include "cube.h" #include "pyramid.h" using namespace std; int main(int argc, char* argv[]) { vector<Shape*> shapes; shapes.push_back(new Shape("Shape")); shapes.push_back(new Cube("Cube")); shapes.push_back(new Pyramid("Pyramid")); for (int i = 0; i < shapes.size(); i++) cout << shapes[i]->toString() << endl; //cout << shapes[i]->getSides() << endl; } Cube *cube2 = new Cube("Cube 2"); cout << cube2->getSides() << endl; Shape cube3("Cube 3"); //cout << cube3.getSides() << endl; return 0; #ifndef CUBE_H #define CUBE_H #include <string> #include <sstream> #include "shape.h" using namespace std; class Cube : public Shape { private: int sides; public: Cube(const string& name) : Shape(name), sides(6) {} int getSides() { return sides; } string Cube::toString() const ostringstream sb; sb << Shape::toString(); return sb.str(); } }; #endif #ifndef SHAPE_H_ #define SHAPE_H_ #include <string> using namespace std; class Shape { private: std::string name; public: Shape(const string& name) : name(name) {} string getName() const { return name; } string toString() const ostringstream sb; sb << "Shape: " << name; return sb.str(); } }; #endif

The friend Declaration Inheritance #include <iostream> using namespace std; class Box { private: double width; public: friend void printWidth(Box box); void setWidth(double wid) { width = wid; } }; void printWidth(Box box) cout << "Width of box = " << box.width << endl; } // Main function for the program int main() Box box; box.setWidth(10.0); printWidth(box); return 0; printWidth() is not a member function of any class. Use friend function to print the wdith – can directly access any member of box.

SNAP UML Iterators Student Course SNAP Csg Cdh Cr -int studID +int getStudID() +toString() const Course -string course +string getCourse() +toString() const SNAP -int studID -string name -string address -string phone +int getStudID() +string getName() +string getAddr() +string getPhone() +toString() const Csg -string course -int studID -string grade +string getCourse() +int getStudID() +string getGrade() +toString() const Cdh -string course -string day -string hour +string getCourse() +string getDay() +string getHour() +toString() const Cr -string course -string room +string getCourse() +string getRoom() +toString() const

SNAP UML Iterators Student Csg Course Cr Cdh SNAP -int studID +int getStudID() +toString() const Csg -string course -int studID -string grade +string getCourse() +int getStudID() +string getGrade() +toString() const Course Cr -string course -string room +string getCourse() +string getRoom() +toString() const Cdh -string course -string day -string hour +string getCourse() +string getDay() +string getHour() +toString() const SNAP -int studID -string name -string address -string phone +int getStudID() +string getName() +string getAddr() +string getPhone() +toString() const

2.1 Program Defects and "Bugs'' Syntax Errors Run-time Errors Logic Errors 2.1, pgs. 130-137

Program Defects and "Bugs" Program Correctness The term "bug" refers to a software defect. Debugging is a commonly used term for removing defects. Easier to eliminate defects by careful design than through testing. Testing is used to show that a program is correct, but it is difficult to determine how much testing needs to be done. testing can never demonstrate the complete absence of defects. complete testing in some environments (missile control software, nuclear power plant controls) is very difficult. You may encounter three kinds of defects or errors: Syntax errors, Run-time errors or exceptions, Logic errors.

Syntax Errors Program Correctness Syntax errors are mistakes in using the grammar (syntax) of the C++ language. The C++ compiler will detect most syntax errors during compilation. Some common syntax errors: Omitting or misplacing braces that bracket compound statements. Invoking a member function that is not defined for the object to which it is applied. Not declaring a variable before using it. Providing multiple declarations of a variable. Not assigning a value to a local variable before referencing it. Not returning a value from a function whose result type is not void. Unfortunately, the compiler may not detect syntax errors that are the result of typographical errors, such as using = when you intended to use ==.

Run-time Errors Program Correctness Run-time errors occur during program execution when the computer or the C++ run-time library detects an operation that it knows to be incorrect. Most run-time errors cause the operating system or run-time library to issue an error message and halt the program. Different computers, operating systems, and compilers handle these errors differently. Some common run-time errors include:

Logic Errors A logic error occurs when the programmer or analyst Program Correctness A logic error occurs when the programmer or analyst makes a mistake in the design of a class. makes a mistake in the design of a class function. has implemented an algorithm incorrectly. uses an incorrect algorithm. The C++ code will compile and run, but will not meet the specifications—it will produce incorrect results. Most logic errors do not cause syntax or run-time errors and, consequently, are difficult to find. Test cases can help find logic errors. Test cases allow the programmer to compare actual program output with the expected results. Software professionals must be diligent in detecting and correcting logic errors.

Logic Error Results Program Correctness The original Mars Lander spacecraft crashed because of inconsistent calculations (feet versus meters). Billing programs have sent out bills for exorbitant amounts of money. ATM programs and off-track betting programs have caused machine owners to lose significant amounts of money. Many popular operating systems have been released with bugs that have allowed hackers to access computers easily and illicitly. A popular word processor when integrated with a document management system "ate" documents off the server leaving an empty file. In the 1980s several patients died after software controlling therapeutic radiation machines gave them massive overdoses. In August 2004, two automobile recalls that could have led to fatal accidents occurred because of software errors in control systems.

Quiz: Identify any syntax, run-time, and/or logic errors: #include <iostream> int findMax(int a[], n) { int max = std::numeric_limits<int>::max(); for (int i = 0; i <= n; i++) if (a[i] > max) max = a[i]; } return max; int main(int argc, char* argv) cout << "Program: " << argv[0] << endl; int a[] = { 7, 5, 3, 10, 2, 6 } cout << "findMax(a) = " << findMax(a, 6); return 0;

Quiz: Identify any syntax, run-time, and/or logic errors: #include <iostream> int findMax(int a[], n) { int max = std::numeric_limits<int>::max(); for (int i = 0; i <= n; i++) if (a[i] > max) max = a[i]; } return max; int main(int argc, char* argv) cout << "Program: " << argv[0] << endl; int a[] = { 7, 5, 3, 10, 2, 6 } cout << "findMax(a) = " << findMax(a, 6); return 0; Syntax Syntax Run-time Logic Run-time Syntax Syntax

3.5, pgs. 213-217 2.2 Exceptions Ways to Indicate an Error The throw Statement Uncaught Exceptions Catching and Handling Exceptions with try and catch Blocks Standard Exceptions The Exception Class Hierarchy Catching All Exceptions 3.5, pgs. 213-217

To Error is Human What to do with an error: Program Correctness What to do with an error: Return a special value. Use a bool return value to indicate success or failure. Set a global variable. Print an error message. Print an error message and exit the program. Put an input or output stream in a fail state. The first three options allow the user of a function to respond to the error. To err is human… But to really screw up, you need a computer!

Exceptions Program Correctness An alternate way to indicate an error, especially if there are several possible errors, is through the use of exceptions. Exceptions are used to signal that an error has occurred during the execution of a program. You can insert code in your program that throws an exception when a particular kind of error occurs. When an exception is thrown, the normal flow of execution is interrupted and control transfers to another part of the program. An exception handler allows the user to catch or handle the exception.

Exception Handling The exception object can be of any type. Program Correctness The exception object can be of any type. The standard library includes standard exception classes. User defined exceptions can be of any data type. If an exception occurs and is not caught, the program stops and an error message is displayed. To avoid uncaught exceptions you write a try block that can throw an exception and follow it with a catch block that catches the exception and handles it. Code within a try/catch block is referred to as protected code. More than one catch block can follow a try block. Each catch block handles a different kind of exception. They are checked in the order in which they appear.

try-catch Blocks Program Correctness try { age = read_int("Enter your age: "); } catch (std::ios_base::failure& f) cerr << "Invalid number format input" << endl; age = DEFAULT_AGE; catch (std::exception& ex) cerr << "Fatal error: " << ex.what() << endl; abort(); catch (...) cerr << "Undefined exception in read_int" << endl; If all statements in the try block execute without error, the exception handler (the catch block) is skipped

When To Use try-catch Blocks Program Correctness When an error event happens routinely and could be considered part of normal execution, handle without throwing exceptions. Use try-catch blocks Around code that can potentially (and unexpectedly) generate an exception. Prevent and recover from application crashes. Throw an exception when your program can identify an external problem that prevents execution. Compared to error reporting via return-codes and if statements, using try / catch / throw is likely to result in code that has fewer bugs, is less expensive to develop, and has faster time-to-market. Constructors and Destructors Constructors don't have a return type, so it's not possible to use return codes, therefore to throw an exception. Destructors should never throw an exception because of stack unwinding.

Standard Exceptions Exception Source bad_alloc bad_cast bad_typeid Program Correctness Exception Source bad_alloc Thrown by new. bad_cast Thrown by dynamic_cast. bad_typeid Thrown by typeid. domain_error Thrown when a mathematically invalid domain is used. length_error Thrown when a too big std::string is created. invalid_argument Thrown due to invalid arguments. out_of_range Thrown by the 'at' method. io_base::failure Thrown by I/O stream objects after erroneous I/O operations. runtime_error Exception that theoretically cannot be detected by reading the code. range_error when you try to store a value which is out of range. overflow_error Thrown if a mathematical overflow occurs. underflow_error Thrown if a mathematical underflow occurs. … Catch all throws

Vector Example animals.at() throws an exception. animals[ ] does not! Program Correctness #include <iostream> #include <vector> #include <string> #include <stdexcept> using namespace std; int main(int aargc, char* argv[]) { vector<string> animals = { "dog", "cat", "horse" }; try for (int i = 0; i < 4; i++) //cout << animals[i] << endl; cout << animals.at(i) << endl; } catch (std::out_of_range& oor) { cerr << oor.what() << endl; } // catch anything thrown within try block that derives from std::exception catch (const std::exception &exc) { cerr << exc.what() << endl; } // catch everything, but can't do anything w/exception. catch (...) { cerr << "???" << endl; } return 0; animals.at() throws an exception. animals[ ] does not!

Define Your Own Program Correctness You can define your own exceptions by inheriting and overriding exception class functionality. #include <iostream> #include <exception> using namespace std; struct MyException : public exception { const char* what() const throw() return "C++ Exception"; } }; int main() try throw MyException(); catch(MyException& e) cout << "MyException caught " << e.what() << endl; catch(exception& e) { cout << e.what() << endl; } //Other errors what() is a public method provided by exception class and it has been overridden by all the child exception classes. This returns the cause of an exception.