CISC 2200 - Data Structures C/C++ Review Fall 2010 1.

Slides:



Advertisements
Similar presentations
1 Classes and Data Abstraction Chapter What a Class ! ! Specification and implementation Private and public elements Declaring classes data and.
Advertisements

C++ Programming: Program Design Including Data Structures, Third Edition Chapter 7: User-Defined Functions II.
Chapter 7: User-Defined Functions II
Kernighan/Ritchie: Kelley/Pohl:
Chapter 3 Data Abstraction: The Walls. © 2005 Pearson Addison-Wesley. All rights reserved3-2 Abstract Data Types Modularity –Keeps the complexity of a.
1 Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington.
Rossella Lau Lecture 8, DCO10105, Semester B, DCO10105 Object-Oriented Programming and Design  Lecture 8: Polymorphism & C++ pointer  Inheritance.
1 C++ Plus Data Structures Nell Dale Chapter 2 Data Design and Implementation Slides by Sylvia Sorkin, Community College of Baltimore County - Essex Campus.
Chapter 6. 2 Objectives You should be able to describe: Function and Parameter Declarations Returning a Single Value Pass by Reference Variable Scope.
1 Lecture 29 Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington.
1 Pointers, Dynamic Data, and Reference Types Review on Pointers Reference Variables Dynamic Memory Allocation –The new operator –The delete operator –Dynamic.
1 Chapter 8 Scope, Lifetime, and More on Functions Dale/Weems/Headington.
1 Procedural Concept The main program coordinates calls to procedures and hands over appropriate data as parameters.
C++ fundamentals.
Review of C++ Programming Part II Sheng-Fang Huang.
OOP Languages: Java vs C++
Chapter 13: Pointers, Classes, Virtual Functions, and Abstract Classes
 2006 Pearson Education, Inc. All rights reserved Classes: A Deeper Look.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 19 Clicker Questions November 3, 2009.
C++ Programming: Program Design Including Data Structures, Fourth Edition Chapter 13: Pointers, Classes, Virtual Functions, and Abstract Classes.
Pointer Data Type and Pointer Variables
Data Structures Using C++ 2E Chapter 3 Pointers and Array-Based Lists.
C++ Programming: From Problem Analysis to Program Design, Fourth Edition Chapter 14: Pointers, Classes, Virtual Functions, and Abstract Classes.
1 Chapter 9 Scope, Lifetime, and More on Functions.
C++ Plus Data Structures Data Design and Implementation
Chapter 2 Data Design and Implementation. Data The representation of information in a manner suitable for communication or analysis by humans or machines.
1 C++ Plus Data Structures Nell Dale David Teague Chapter 2 Data Design and Implementation Slides by Sylvia Sorkin, Community College of Baltimore County.
1 Basic Concepts of Object-Oriented Design. 2 What is this Object ? There is no real answer to the question, but we ’ ll call it a “ thinking cap ”. l.
 2006 Pearson Education, Inc. All rights reserved Arrays.
A First Book of C++: From Here To There, Third Edition2 Objectives You should be able to describe: Function and Parameter Declarations Returning a Single.
1 Chapter 8 Scope, Lifetime, and More on Functions Dale/Weems/Headington.
Chapter 6: User-Defined Functions
C++ Programming: From Problem Analysis to Program Design, Fifth Edition, Fifth Edition Chapter 7: User-Defined Functions II.
Overloading Binary Operators Two ways to overload –As a member function of a class –As a friend function As member functions –General syntax Data Structures.
SEN 909 OO Programming in C++ Final Exam Multiple choice, True/False and some minimal programming will be required.
Copyright 2003 Scott/Jones Publishing Standard Version of Starting Out with C++, 4th Edition Chapter 13 Introduction to Classes.
1 2 Data Design and Implementation Chapter 2 Data Design and Implementation.
Data Structures Using C++ 2E Chapter 3 Pointers. Data Structures Using C++ 2E2 Objectives Learn about the pointer data type and pointer variables Explore.
Chapter 12: Pointers, Classes, Virtual Functions, and Abstract Classes.
User Defined Functions Chapter 7 2 Chapter Topics Void Functions Without Parameters Void Functions With Parameters Reference Parameters Value and Reference.
C++ Programming Basic Learning Prepared By The Smartpath Information systems
Introduction to c++ programming - object oriented programming concepts - Structured Vs OOP. Classes and objects - class definition - Objects - class scope.
Chapter 10: Classes and Data Abstraction. Objectives In this chapter, you will: Learn about classes Learn about private, protected, and public members.
Functions Illustration of: Pass by value, reference Scope Allocation Reference: See your CS115/215 textbook.
 2008 Pearson Education, Inc. All rights reserved. 1 Arrays and Vectors.
Functions Math library functions Function definition Function invocation Argument passing Scope of an variable Programming 1 DCT 1033.
Fall 2013CISC2200 Yanjun Li1 Review. Fall 2013CISC2200 Yanjun Li2 Outline Array Pointer Object-Oriented Programming.
Chapter 8 Arrays. A First Book of ANSI C, Fourth Edition2 Introduction Atomic variable: variable whose value cannot be further subdivided into a built-in.
1 Classes II Chapter 7 2 Introduction Continued study of –classes –data abstraction Prepare for operator overloading in next chapter Work with strings.
Chapter 1 Data Abstraction: The Walls CS Data Structures Mehmet H Gunes Modified from authors’ slides.
1 Chapter 9 Scope, Lifetime, and More on Functions.
Chapter 11: Inheritance and Composition. Introduction Two common ways to relate two classes in a meaningful way are: – Inheritance (“is-a” relationship)
Chapter 10: Classes and Data Abstraction. Classes Object-oriented design (OOD): a problem solving methodology Objects: components of a solution Class:
1 Chapter 15-1 Pointers, Dynamic Data, and Reference Types Dale/Weems.
Object-Oriented Programming (OOP) and C++
1 n Object Oriented Programming. 2 Introduction n procedure-oriented programming consists of writing a list of instructions and organizing these instructions.
Dynamic Memory Management & Static Class Members Lecture No 7 Object Oriented Programming COMSATS Institute of Information Technology.
Chapter 12: Pointers, Classes, Virtual Functions, Abstract Classes, and Lists.
1 Classes and Data Abstraction Chapter What a Class ! ! Specification and implementation Private and public elements Declaring classes data and.
1 Chapter 12 Classes and Abstraction. 2 Chapter 12 Topics Meaning of an Abstract Data Type Declaring and Using a class Data Type Using Separate Specification.
Chapter 12 Classes and Abstraction
Chapter 7: User-Defined Functions II
About the Presentations
User-Defined Functions
Chapter 9 Scope, Lifetime, and More on Functions
Classes and Data Abstraction
Pointers, Dynamic Data, and Reference Types
7 Arrays.
Pointers, Dynamic Data, and Reference Types
Presentation transcript:

CISC Data Structures C/C++ Review Fall

Outline 2  Arrays  Pointers and Dynamic Memory Allocation  Object-Oriented Programming  Basic concepts: class, object  Encapsulation  Inheritance  Polymorphism

Array  Arrays are data structures containing related data items of same type.  An array is a consecutive group of memory locations. 3

Declare an Array 4  Declaration of an array: type arrayName[ arraySize ];  Example  int c[ 12 ];  arraySize must be an integer constant greater than zero.  type specifies the types of data values to be stored in the array: can be int, float, double, char, etc.

Useful Memory Diagram 5

Elements of An Array 6  To refer to a particular location or element in the array, we specify:  name of the array  index of the element: integer or integer expression, with value larger than or equal to 0.  First element has index zero.  Example C[0] += 2; C[a + b] = 3;

Example 7  An array c has 12 elements ( c[ 0 ], c[ 1 ], … c[ 11 ] ); the value of c[ 0 ] is –45.

Initialize Array with Initializer List 8  Initializer list: items enclosed in braces ({}) and separated by commas.  Examples  int n[ 5 ] = { 10, 20, 30, 40, 50 };  int m[ 5 ] = { 10, 20, 30 };  The remaining elements are initialized to zero.  int p[ ] = { 10, 20, 30, 40, 50 };  Because array size is omitted in the declaration, the compiler determines the size of the array based on the size of the initializer list.

Initialize an Array Using a Loop 9  Using a loop to initialize the array’s elements  Declare array, specify number of elements  Use repetition statement to loop for each element  Example: int n[10]; for ( int i = 0; i < 10; i++) { n[ i ] = 0; }

Using An Array 10  Usually use for loop to access each element of an array.  C++ has no array boundary checking  Referring to an element outside the array bounds is an execution-time logic error. It is not a syntax error.  You need to provide correct index.

Using An Array – Example 1 11  Example: summing the elements of an array const int arraySize = 6; int a [ arraySize ] = { 87, 69, 45, 45, 43, 21 }; int total = 0;// need to initialize it!!! for ( int i = 0; i < arraySize; i++) { total += a[i]; } cout << “Total of array elements is ” << total << endl;

Parameter Passing Review 12  Task: write an ExchangeValues function that exchanges the values of two parameters, both integers. int x=10, y=20; ExchangeValues(x,y); cout << “x=“ << x << endl; cout << “y=“ << y << endl; Should print out: x=20 y=10

Function Using Pass by Value 13 void ExchangeValues(int a, int b) { int tmp; tmp = a; a = b; b = tmp; } int main(int argc, char ** argv) { int myInteger1=4; int myInteger2=5; ExchangeValues(myInteger1,myInteger2); cout<<“integer1= “<<myInteger1<<endl; cout<<“integer2=“<<myInteger2<<endl; } a,b: formal parameters actual parameters Does it work ? Pass by value: A copy of the value of myInterger1 and myInterger2 are passed to ExchangeValue.

C++ Tips 14 CALLING BLOCK FUNCTION CALLED Pass-by-value sends a copy of the value of the actual parameter SO, the actual parameter cannot be changed by the function

C++ Tips 15 CALLING BLOCK FUNCTION CALLED Pass-by-reference sends the location (memory address) of the actual parameter the actual parameter can be changed by the function

16 Pass-by-reference  Good for performance reasons: eliminates copying overhead  Called the same way as call-by-value int squareByValue (int x); int squareByReference (int & x); int x,z; … squareByValue(x); squareByReference(z);  Bad for security: called function can corrupt caller’s data  Solution: use const qualifier

C/C++ function: Pass by reference 17 void ExchangeValue(int & a, int & b) { int tmp; tmp = a; a = b; b = tmp; } int main( ) { int value1=4; int value2=5; int result=ExchangeValue(value1,vaule2); cout<<“value= “<<value1<<endl<<“value2=“<<value2<<endl; } a,b: formal parameters actual parameters Now it works !

Passing Arrays as Parameters 18  In C/C++, arrays are always passed by reference  & is not used in the formal parameter type.  Whenever an array is passed as a parameter, its base address (address of first element) is sent to called function.  Example: // prototype float SumValues (float values [ ], int numOfValues );

const array parameter If the function is not supposed to change the array: you can protect the array from unintentional changes; use const in the formal parameter list and function prototype. FOR EXAMPLE... // prototype float SumValues(const float values[ ], int numOfValues ); 19 If there is statement inside SumValues() that changes the values array, the compiler will report an error.

// values[0] through values[numOfValues-1] // have been assigned // Returns the sum of values[0] through // values[numOfValues-1] 20 float SumValues (const float values[ ], int numOfValues ) { float sum = 0; for ( int index = 0; index < numOfValues; index++ ) { sum += values [ index ] ; } return sum; }

Outline 21  Array  Pointers and Dynamic Memory Allocation  Introduction to Abstract Data Types  Object-Oriented Programming  Basic concept: class, object  Encapsulation  Inheritance  Polymorphism

Pointer Variable 22  A variable whose value is the address of a location in memory  i.e., a variable that points to some address in memory…  type * pointer_variable_name; int* intPointer;

Assign Value to Pointer 23 int alpha; int* intPointer; intPointer = α If alpha is at address 33, memory looks like this alpha

Pointer Types 24 int x; x = 12; int* ptr; ptr = &x; Because ptr holds the address of x, we say that ptr “points to” x x ptr

Pointer: Dereference Operator (*) 25  An operator that, when applied to a pointer variable, denotes the variable to which the pointer points (content) int x; x = 12; int* ptr; ptr = &x; cout << *ptr; *ptr is the value in the place to which ptr points x ptr

Pointer: Dereference Operator (*) 26 int x; x = 12; int* ptr; ptr = &x; *ptr = 5; // changes the value // at address ptr to x ptr

Pointer Types 27 char ch; ch = ‘A’; char* q; q = &ch; *q = ‘Z’; char* p; p = q; // the right side has value 4000 // now p and q both point to ch 4000 A Z ch q p

Pointer Types 28  All pointer variables should be initialized to be NULL  A pointer that points to nothing; available in  NULL is defined to be 0;  But NULL is not memory address 0 int * intPtr = NULL; float * money = NULL; intPtrmoney

29 Review: lifetime of variables or objects  Global variables/objects: start from before the program starts until main() ends int num; main(){ …. }  Local variables/objects: declared within the body of a function or a block  Created upon entering the function/block, destroyed upon exiting the function/block  Dynamic variables/objects: created using new(), malloc() calls  Remain alive until delete() is called to free the memory  Destroyed when the program exits

Dynamic allocation (new operator) 30  Allocation of memory space for a variable at run time (as opposed to static allocation at compile time) int * intPointer; intPointer = new int;

31 Deallocate allocated memory  Dynamically allocated memory needs to be deallocated when it’s no longer used  Otherwise, memory leak will degrade performance  delete operator returns memory to system delete p;  Value of p is unchanged, i.e. pointing to deallocated memory  Accessing a deallocated memory ( *p ) can be dangerous  Always set to NULL after deallocation delete p; // free up memory pointed to by p p = NULL; // safeguard, extremely important

32 Pointers: examples (a) Declaring pointer variables; (b) pointing to statically allocated memory; (c) assigning a value; (d) allocating memory dynamically; (e) assigning a value

33 Pointers: example (cont’d) This memory space cannot be deallocated, as we don’t have a pointer …

34 Dynamically Allocated Arrays  Use new operator to allocate an array dynamically int arraySize; //ask user to enter arraySize… // double *anArray = new double[arraySize];  arraySize has a value determined at run time  Dynamically allocated array can be increased double *oldArray = anArray; anArray = new double[2*arraySize]; // copy from oldArray to anArray delete [] oldArray; // deallocate oldArray

Outline 35  Array  Pointer and Dynamic Memory Allocation  Introduction to Abstract Data Types  Object-Oriented Programming  Basic concept: class, object  Encapsulation  Inheritance  Polymorphism

Let’s focus on: Data  Data: the representation of information in a manner suitable for communication or analysis by humans or machines  Data are the nouns of the programming world:  The objects that are manipulated.  The information that is processed.  Different view about data  Application view: What real life objects can be modeled using the data?  Logical view: How to use the data? Operations?  Implementation view: How to implement the data? 36

37 C++ Built-In Data Types Composite array struct union class Address pointer reference Simple IntegralFloating char short int long enum float double long double

Using C/C++ Data Type  As a C/C++ programmer, we know  Based on the application, we model data as different “variables”  Age: integer  Gender: enumeration  Name: array of char, or string  Also we know what kind of operations each data type supports  We do not worry about how an integer is implemented 38

C++ programs are users of int 39 Value range: INT_MIN.. INT_MAX Operations: + prefix - prefix + infix - infix * infix / infix % infix Relational Operators infix TYPE int (inside) Representation of int as 16 bits two’s complement + Implementation of Operations

Different Views of Data 40  Application (or user) level modeling real-life data in a specific context  When to use a certain data type?  Logical (or ADT) level abstract view of the domain and operations  How to use the data type?  Implementation level specific representation of the structure to hold the data items, and the coding for operations  How to implement the data type?

Different Views of Data: Library Example 41  Application (or user) level Library of Congress, or Baltimore County Public Library  A library system can be implemented for Library of Congress…  Logical (or ADT) level domain is a collection of books; operations include: check book out, check book in, pay fine, reserve a book  A library’s necessary functions to the outside world  Implementation level representation of the structure to hold the “books” and the coding for operations  How a specific library is implemented (how are books organized…)?

Different Views of Data 42  Application (or user) level: modeling real-life data in a specific context.  Logical (or ADT) level: abstract view of the domain and operations. WHAT  Implementation level: specific representation of the structure to hold the data items, and the coding for operations. HOW

Logical view of array: All a C++ program needs to know 43  One-dimensional array  A structured composite data type made up of a finite, fixed size collection of ordered homogeneous elements to which direct access is available Logical level int numbers[10]

44  A two-dimensional array  A structured composite data type made up of a finite, fixed size collection of homogeneous elements ordered in two dimensions and for which direct access is provided:  dataTable[row][col] logical level int dataTable[10][6]; Logical view of 2D array: All a C++ program needs to know

Many recurrent data types  List  Queue: First In First Out  Operating System: process queues, printing job queue  Stack: Last in First out  Calling stack  Compiler: to parse expressions  Graph:  Model computer network  …. 45 Provide a high-level data type with these logical properties

Data Abstraction: the idea 46  Data Abstraction: the separation of a data type’s logical properties from its implementation  User of the data type only needs to understand its logical property, no need to worry about its implementation LOGICAL PROPERTIESIMPLEMENTATION What are the possible values?How can this be done in C++? What operations will be needed?

Abstract Data Type: A logical view 47  Abstract Data Type is a specification of  a set of data  the set of operations that can be performed on the data  Constructors: to creates new instances of an ADT; usually a language feature  Transformers (mutators): operations that change the state of one or more data values in an ADT  Observers: operations that allow us to observe the state of the ADT  Iterators: operations that allow us to access each member of a data structure sequentially  Abstract Data Type is implementation independent

Outline 48  Array  Pointer and Dynamic Memory Allocation  Introduction to Abstract Data Type  Object-Oriented Programming  Basic concept: class, object  Encapsulation  Inheritance  Polymorphism

OOP & ADT 49  Object-oriented language provide mechanism for specifying ADT and implementing ADT  Class  An unstructured type that encapsulates a fixed number of data components (data members) with the functions (member functions) that manipulate them  predefined operations on an instance of a class are whole assignment and component access  Client  Software that uses (declares and manipulates) objects (instances) of a particular class to solve some problem

Object-Oriented Programming: Basics 50  Class  an unstructured type that encapsulates a fixed number of data components (data members) with the functions (called member functions) that manipulate them.  Object  An instance of a class  Method  A public member function of a class  Instance variable (Data Member)  A private data member of a class

Higher-Level Abstraction 51  Class specification  A specification of the class members (data and functions) with their types and/or parameters  Class implementation  The code that implements the class functions Why would you want to put them in separate files?

Classes vs. Structs 52  Without using public and private, member functions and data are  private by default in classes  public by default in structs.  Usually, there is no member functions defined in structs  struct is passive data  class is active data

class DateType Specification 53 // SPECIFICATION FILE( datetype.h ) class DateType// declares a class data type { public : // 4 public member functions DateType (int newMonth,int newDay,int newYear);//constructor int getYear( ) const ; // returns year int getMonth( ) const ; // returns month int getDay( ) const ; // returns day private : // 3 private data members int year ; int month ; int day ; } ; 53

Use of C++ data type class 54  Variables of a class type are called objects (or instances) of that particular class.  Software that declares and uses objects of the class is called a client.  Client code uses public member functions (called methods in OOP) to handle its class objects.  Sending a message means calling a public member function.

Client Code Using DateType 55 #include “datetype.h” //includes specification of the class #include using namespace std; int main ( ) { // declares two objects of DateType DateType startDate ( 6, 30, 1998 ) ; DateType endDate ( 10, 31, 2002 ) ; bool retired = false ; cout << startDate.getMonth( )<< “/” << startDate.getDay( ) << “/” << startDate.getYear( ) << endl; while ( ! retired ) { finishSomeTask( ) ;... } return 0; } 55 How to dynamically create a DateType object ?

2 separate files for class type 56 // SPECIFICATION FILE ( datetype.h ) // Specifies the data and function members. class DateType { public:... private:... } ; // IMPLEMENTATION FILE ( datetype.cpp ) // Implements the DateType member functions....

Implementation of member functions 57 // IMPLEMENTATION FILE (datetype.cpp) #include “datetype.h” // also must appear in client code DateType :: DateType ( int newMonth, int newDay, int newYear ) // Post: year is set to newYear. // month is set to newMonth. // day is set to newDay. { year = newYear ; month = newMonth ; day = newDay ; } 57 :: Scope resolution operator

58 C++ Classes: Constructors  Invoked/called (automatically) when an object of the class is declared/created  A class can have several constructors  A default constructor has no arguments  different constructors with different parameter list (signature)  Eg. DateType can be extended to have the following constructor :  DateType (int secondsSinceEpoch);  The compiler will generate a default constructor if you do not define any constructors

59 int DateType :: getMonth ( ) const // Accessor function for data member month { return month ; } int DateType :: getYear ( ) const // Accessor function for data member year { return year ; } int DateType :: getDay ( ) const // Accessor function for data member day { return day ; } 59

60 C++ Classes: Destructors*  Called (automatically) when an object’s lifetime ends  To free up resources taken by the object, esp. memory  Each class has one destructor  If you don’t need to free up resources, you can omit define destructor and the compiler will generate a default destructor

61 C++ Namespaces*  A mechanism for logically grouping declarations and definitions into a common declarative region namespace myNamespace { // Definitions // Declarations... } //end myNamespace  The contents of the namespace can be accessed by code inside or outside the namespace  Use the scope resolution operator (::) to access elements from outside the namespace  Alternatively, the using declaration allows the names of the elements to be used directly

62 C++ Namespace: simple example*  Creating a namespace namespace smallNamespace { int count = 0; void abc(); } // end smallNamespace  Using a namespace smallNamesapce::count=0; using namespace smallNamespace; count +=1; abc();

63 C++ std namespace*  Items declared in the C++ Standard Library are declared in the std namespace  You include files for several functions declared in the std namespace  To include input and output functions from the C++ library, write #include using namespace std;

Encapsulation 64  Just as a capsule protects its contents, the class construct protects its data members // SPECIFICATION FILE( datetype.h ) class DateType { Public : DateType (int newMonth,int newDay,int newYear);//constructor int getYear( ) const ; int getMonth( ) const ; int getDay( ) const ; private : int year ; int month ; int day ; } ;

Object-Oriented Programming 65  Three ingredients in any object-oriented language  encapsulation  inheritance  polymorphism

Inheritance 66  Inheritance: A mechanism used with a hierarchy of classes in which each descendant class inherits the properties (data and operations) of its ancestor class  Base class  The class being inherited from  Derived class  the class that inherits Inheritance is an "is-a" …

Overriding & Polymorphism 67  Polymorphism: the ability to determine which of several operations with the same name (within the class hierarchy) is appropriate, either at compiling time (static binding) or run time (dynamic binding)  Overriding Function with virtual keyword in base class. Derived classes override function as appropriate. An overridden function in a derived class has the same signature and return type (i.e. prototype) as the function it overrides in its base class.

Example: Overriding 68 Person Employee Manager Each class has a method Print Person.Print just prints the name Employee.Print prints the name and job title Manager.Print prints name, job title, and department Print is overriden. * Static binding is when the compiler can tell which Print to use * dynamic binding is when the determination cannot be made until run time => use the virtual keyword

Object-Oriented Programming 69  Inheritance and polymorphism work together to allow programmer to build useful hierarchies of classes that can be put into a library to be reused in different applications  Examples:  Employee class can reuse features implemented at Person class  Only override functions when needed, like print()  A program working for Person class still work for Employee object (through polymorphism)  Print out all persons,…

Miscellaneous: I/O in C++ 70  Header files iostream and fstream declare the istream, ostream,and ifstream, ofstream I/O classes.  Both cin and cout are class objects  These statements declare myInfile as an instance of class ifstream and invoke member function open. ifstream myInfile ; myInfile.open ( “A:\\mydata.dat” ) ;

Reference 71  Reproduced from C++ Plus Data Structures, 4 th edition by Nell Dale.  Reproduced by permission of Jones and Bartlett Publishers International.  Modified based on Dr. Li and Dr. Zhang’s slides