+ All Categories
Home > Documents > Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Date post: 04-Jan-2016
Category:
Upload: joshua-cruz
View: 20 times
Download: 4 times
Share this document with a friend
Description:
Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington. Chapter 11 Topics. Meaning of a Structured Data Type Declaring and Using a struct Data Type C++ union Data Type Meaning of an Abstract Data Type Declaring and Using a class Data Type - PowerPoint PPT Presentation
82
1 Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington
Transcript
Page 1: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

1

Chapter 11

Structured Types,

Data Abstraction and Classes

Dale/Weems/Headington

Page 2: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

2

Chapter 11 Topics Meaning of a Structured Data Type Declaring and Using a struct Data Type C++ union Data Type Meaning of an Abstract Data Type Declaring and Using a class Data Type Using Separate Specification and

Implementation Files Invoking class Member Functions in Client

Code C++ class Constructors

Page 3: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

3

C++ Data TypesC++ Data Types

structured

array struct union class

address

pointer reference

simple

integral enum

char short int long bool

floating

float double long double

Page 4: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

4

Structs

Page 5: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

5

Structured Data Type

A structured data type is a type in which each value is a collection of component items.

the entire collection has a single name

each component can be accessed individually

Page 6: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

6

C++ Structured Type

often we have related information of various types that we’d like to store together for convenient access under the same identifier, for example . . .

Page 7: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

7

thisAnimal

5000

.id 2037581

.name “giant panda”

.genus “Ailuropoda”

.species “melanoluka”

.country “China”

.age 18

.weight 234.6

.health Good

Page 8: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

8

anotherAnimal

6000

.id 5281003

.name “llama”

.genus “Lama”

.species “peruana”

.country “Peru”

.age 7

.weight 278.5

.health Excellent

Page 9: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

9

struct AnimalType

enum HealthType { Poor, Fair, Good, Excellent } ;

struct AnimalType // declares a struct data type{ // does not allocate memory

int id ;string name ;string genus ;string species ; struct members string country ; int age ; float weight ;

} ;

AnimalType thisAnimal ; // declare variables of AnimalType

AnimalType anotherAnimal ;

Page 10: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

10

struct type Declaration

SYNTAX struct TypeName // does not allocate memory {

MemberList } ;

MemberList SYNTAX

DataType MemberName ;

DataType MemberName ; . . .

Page 11: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

11

struct type Declaration

The struct declaration names a type and names the members of the struct.

It does not allocate memory for any variables of that type!

You still need to declare your struct variables.

Page 12: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

12

More about struct type declarations

If struct type declaration precedes all functions visible throughout the rest of the file (global scope).

If it is placed within a function, only that function can use it (local scope).

Common to place struct type decl. in (.h) header file#include that file.

Page 13: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

13

More about struct type declarations

Members of different struct types MAY have the same identifiers (names).

struct Student struct Instructor

{ {int id; int id;

float gpa; float salary;

} }

Non-struct variable MAY have the same identifier as a structure member.

Student s;

float gpa;

Page 14: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

14

Accessing struct Members

Dot ( period ) is the member selection operator.

After struct type declaration: struct members can be used in your program only when they are preceded by

– dot– a struct variable name

EXAMPLESAnimalType thisAnimal,

anotherAnimal;thisAnimal.weightanotherAnimal.country

Page 15: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

15

Valid operations on a struct member depend only on its type

thisAnimal.age = 18;

thisAnimal.id = 2037581;

cin >> thisAnimal.weight;

getline ( cin, thisAnimal.species );

thisAnimal.name = “giant panda”;

thisAnimal.genus[ 0 ] = toupper (thisAnimal.genus[ 0 ] ) ;

thisAnimal.age++;

struct AnimalType { long id ;

string name ;string genus ;string species; string country

int age ;

float weight ;

HealthType health ;

} ;

AnimalType thisAnimal;

Page 16: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

16

Aggregate Operations

Page 17: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

17

Aggregate Operation

is an operation on a

data structure as a whole

as opposed to an operation on an individual component of the data structure

Page 18: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

18

Aggregate struct Operations

NOT ALLOWED I/O arithmetic comparisons of entire struct variables

Operations ALLOWED on entire struct variable:

assignment to another struct variable of same type pass to a function as argument (by value or by reference)

return as value of a function

see time1.cpp time2.cpp

Page 19: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

19

Examples of aggregate struct operations

anotherAnimal = thisAnimal ; // assignment

WriteOut(thisAnimal); // value parameter

ChangeWeightAndAge(thisAnimal); // reference parameter

thisAnimal = GetAnimalData( ); // return value of function

NOW WE’LL WRITE THE 3 FUNCTIONS USED HERE . . .

Page 20: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

20

void WriteOut( /* in */ AnimalType thisAnimal)

// Prints out values of all members of thisAnimal

// Precondition: all members of thisAnimal are assigned

// Postcondition: all members have been written out{

cout << “ID # “ << thisAnimal.id << thisAnimal.name << endl ;

cout << thisAnimal.genus << thisAnimal.species << endl ;

cout << thisAnimal.country << endl ;

cout << thisAnimal.age << “ years “ << endl ;

cout << thisAnimal.weight << “ lbs. “ << endl ;

cout << “General health : “ ;

WriteWord ( thisAnimal.health ) ;}

Page 21: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

21

void ChangeAge ( /* inout */ AnimalType& thisAnimal )

// Adds 1 to age// Precondition: thisAnimal.age is assigned // Postcondition: thisAnimal.age == thisAnimal.age@entry + 1

{

thisAnimal.age++ ;

}

Passing a struct Type by Reference

Page 22: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

22

AnimalType GetAnimalData ( void )

// Obtains all information about an animal from keyboard

// Postcondition:// Function value == AnimalType members entered at kbd{

AnimalType thisAnimal ;

char response ;

do { // have user enter all members until they are correct.

.

.

} while (response != ‘Y’ ) ;

return thisAnimal ;

}

Page 23: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

23

Hierarchical Structures

Page 24: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

24

Hierarchical Structures

A struct member can be of another struct type.

This is called nested or hierarchical structures.

Hierarchical structures are useful when there is detailed info in each record.

FOR EXAMPLE . . .

Page 25: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

25

struct MachineRec

Information about each machine in a shop contains:

an idNumber,

a written description,

the purchase date,

the cost,

and a historical statistics (including failure rate, number of days down, and date of last service).

Page 26: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

26

struct DateType

{ int month ; // Assume 1 . . 12

int day ; // Assume 1 . . 31

int year ; // Assume 1900 . . 2050

};

struct StatisticsType

{ float failRate ;

DateType lastServiced ; // DateType is a struct type

int downDays ;

} ;

struct MachineRec

{ int idNumber ;

string description ;

StatisticsType history ; // StatisticsType is a struct type

DateType purchaseDate ;

float cost ;

} ;

MachineRec machine ;

Page 27: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

27

struct type variable machine

7000

.idNumber .description . history .purchaseDate .cost

.month .day .year

5719 “BULLDOZ…” 3 21 1995 78000.

.failrate .lastServiced .downdays

.02 6 25 1999 4.month .day .year

machine.history.lastServiced.year has value 1999

Page 28: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

28

Unions

Page 29: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

29

Unions in C++

DEFINITION

A union is a struct that holds only one of its members at a time during program execution.

EXAMPLE

union WeightType

{

long wtInOunces ; int wtInPounds; only one at a time

float wtInTons;

} ;

Page 30: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

30

Using Unions

union WeightType // declares a union type

{

long wtInOunces ;

int wtInPounds;

float wtInTons;

} ;

WeightType weight; // declares a union variable

weight.wtInTons = 4.83 ;

// Weight in tons is no longer needed. Reuse the memory space.

weight.wtInPounds = 35; // see Unionex.cpp

Page 31: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

31

Abstraction

Page 32: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

32

Abstraction

Is the separation of the essential qualities of an object from the details of how it works or is composed

Essential qualities <<<<>>>> details

Focuses on what, not how Like a table of contents Is necessary for managing large, complex

software projects

Page 33: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

33

Control Abstraction separates the logical properties of an action

from its implementation logical properties <<<>>> implementation

. . .

Search (list, item, length, where, found); . . .

the function call depends on the function’s specification (description), not its implementation (algorithm)

Page 34: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

34

Data Abstraction

separates the logical properties of a data type from its implementation

LOGICAL PROPERTIES IMPLEMENTATION

What are the possible values? How can this be done in C++?

What operations will be needed? How can existing data types be used?

Page 35: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

35

Data Type

set of values(domain)

allowable operationson those values

FOR EXAMPLE, data type short has

domain

-32768 . . . 32767

operations

+, -, *, /, %, >>, <<

Page 36: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

36

Abstract Data Type

Page 37: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

37

Abstract Data Type (ADT)

a data type whose properties (domain and operations) WHAT

are specified independently of any particular implementation HOW

FOR EXAMPLE . . .

Page 38: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

38

ADT Specification Example (Properties)

TYPETimeType

DOMAIN

Each TimeType value is a time in hours, minutes, and seconds.

OPERATIONSSet the time

Print the time

Increment by one second

Compare 2 times for equality

Determine if one time is “less than” another

Notice NO Implementation given!!

Page 39: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

39

Another ADT Specification

TYPEComplexNumberType

DOMAIN

Each value is an ordered pair of real numbers (a, b) representing a + bi.

OPERATIONSInitialize the complex number

Write the complex number

Add

Subtract

Multiply

Divide

Determine the absolute value of a complex number

Notice NO Implementation given!!

Page 40: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

40

ADT Implementation means

choosing a specific data representation for the abstract data using data types that already exist (built-in or programmer-defined)

writing functions for each allowable operation

Page 41: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

41

10 45 27

Several Possible Representations of TimeType

3 int variables

3 strings

3-element int array

actual choice of representation depends on time, space, and algorithms needed to implement operations

10 45 27

“10” “45” “27”

Page 42: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

42

Some Possible Representationsof ComplexNumberTypestruct with 2 float members

2-element float array

-16.2 5.8

-16.2 5.8

.real .imag

Page 43: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

43

Classes

Page 44: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

44

C++ Data TypesC++ Data Types

structured

array struct union class

address

pointer reference

simple

integral enum

char short int long bool

floating

float double long double

Page 45: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Class A structured type

(many components, access to each) in a programming language used to represent an ADT

Not a passive data structure (only being acted upon)

An active data structure containing data & operations in a single unit

Page 46: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

46

class TimeType Specification// SPECIFICATION FILE ( timetype.h )

class TimeType // declares a class data type{ // does not allocate memory

public : // 5 public function members

void Set ( int hours , int mins , int secs ) ;void Increment ( ) ;void Write ( ) const ;bool Equal ( TimeType otherTime ) const ; bool LessThan ( TimeType otherTime ) const ;

private : // 3 private data members

int hrs ; int mins ; int secs ;

} ;

Page 47: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

47

Use of C++ data Type class

facilitates re-use of C++ code for an ADT

software that uses the class is called a client

variables of the class type are called class objects or class instances

client code uses public member functions to handle its class objects

Page 48: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

48

Client Code Using TimeType#include “timetype.h” // includes specification of the classusing namespace std ;

int main ( ){

TimeType currentTime ; // declares 2 objects of TimeType TimeType endTime ; bool done = false ;

currentTime.Set ( 5, 30, 0 ) ; endTime.Set ( 18, 30, 0 ) ; while ( ! done )

{ . . .

currentTime.Increment ( ) ;if ( currentTime.Equal ( endTime ) )

done = true ; } ;}

Page 49: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

49

class type Definition

The class definition creates a data type and names the members of the class.

It does not allocate memory for any variables of that type!

Client code still needs to declare class variables.

Page 50: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

50

C++ Data Type class represents an ADT

2 kinds of class members: data members and function members

class members are private by default

data members are generally private

function members are generally declared public

private class members can be accessed only by the class member functions (and friend functions), not by client code.

Page 51: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

51

class TimeType Specification// SPECIFICATION FILE ( timetype.h )

class TimeType // declares a class data type{ // does not allocate memory

public : // 5 public function members

void Set ( int hours , int mins , int secs ) ;void Increment ( ) ;void Write ( ) const ;bool Equal ( TimeType otherTime ) const ; bool LessThan ( TimeType otherTime ) const ;

private : // 3 private data members

int hrs ; int mins ; int secs ;

} ;

Page 52: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

52

Aggregate class Operations

built-in operations valid on class objects are:

member selection using dot ( . ) operator ,

assignment to another class variable using ( = ),

pass to a function as argument

(by value or by reference),

return as value of a function

other operations can be defined as class member functions

Page 53: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

53

2 separate files Generally Used for class Type

// SPECIFICATION FILE ( timetype .h ) // Specifies the data and function members. class TimeType { public: . . .

private: . . . } ;

// IMPLEMENTATION FILE ( timetype.cpp ) // Implements the TimeType member functions.

. . .

Page 54: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

54

Implementation File for TimeType

// IMPLEMENTATION FILE ( timetype.cpp ) // Implements the TimeType member functions.

#include “ timetype.h” // also must appear in client code #include <iostream>

. . .

bool TimeType :: Equal ( /* in */ TimeType otherTime ) const // Postcondition: // Function value == true, if this time equals otherTime // == false , otherwise { return ( (hrs == otherTime.hrs) && (mins == otherTime.mins) && (secs ==

otherTime.secs) ) ; }

. . . // see s:\cp2\cpp\time\TestTime

Page 55: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

55

Familiar Class Instances and Function Members

the member selection operator ( . ) selects either data members or function members

header files iostream and fstream declare the istream, ostream,and ifstream, ofstream I/O classes

both cin and cout are class objects and get and ignore are function members

cin.get (someChar) ;cin.ignore (100, ‘\n’) ;

these statements declare myInfile as an instance of class ifstream and invoke function member open

ifstream myInfile ;

myInfile.open ( “A:\\mydata.dat” ) ;

Page 56: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

56

Information Hiding

Class implementation details are hidden from the client’s view. This is called information hiding.

Public functions of a class provide the interface between the client code and the class objects.

clientcode

specification implementation

abstraction barrier

Page 57: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

57

Information Hiding" "... the purpose of hiding is to make inaccessible certaindetails that should not affect other parts of a system."

-- [Ross et al, 1975]

"... [I]nformation hiding: a module is characterized by theinformation it hides from other modules, which are called itsclients. The hidden information remains a secret to the clientmodules."

-- [Ghezzi et al, 1991]

"[Information hiding is] the principle that users of a softwarecomponent (such as a class) need to know only the essentialdetails of how to initialize and access the component, and do notneed to know the details of the implementation."

-- [Budd, 1991]

"The technique of encapsulating software design decisions inmodules in such a way that the module's interfaces reveal littleas possible about the module's inner workings; thus each module isa 'black box' to the other modules in

-- [IEEE, 1983]

"The process of hiding all the details of an object that do notcontribute to its essential characteristics; typically, thestructure of an object is hidden, as well as the implementationof its methods. The terms information hiding and encapsulationare usually interchangeable."

-- [Booch, 1991]

Page 58: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

58

Scope Resolution Operator ( :: ) C++ programs typically use several class types

different classes can have member functions with the same identifier, like Write( )

member selection operator is used to determine the class whose member function Write( ) is invoked

currentTime .Write( ) ; // class TimeTypenumberZ .Write( ) ; // class ComplexNumberType

in the implementation file, the scope resolution operator is used in the heading before the function member’s name to specify its class

void TimeType :: Write ( ) const{ . . .

}

Page 59: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

59

TimeType Class Instance Diagrams

Private data:

hrs

mins

secs

Set

Increment

Write

LessThan

Equal

Private data:

hrs

mins

secs

Set

Increment

Write

LessThan

Equal

17

58

2

18

30

0

currentTime endTime

Page 60: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

60

Use of const with Member Functions

when a member function does not modify private data members

use const in both function prototype (specification file) heading of function implementation (implementation file)

Page 61: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

61

class TimeType Specification// SPECIFICATION FILE ( timetype.h )

class TimeType // declares a class data type{ // does not allocate

memory

public : // 5 public function members

void Set ( int hours , int mins , int secs ) ;void Increment ( ) ;void Write ( ) const ;bool Equal ( TimeType otherTime ) const ; bool LessThan ( TimeType otherTime ) const ;

private : // 3 private data members

int hrs ; int mins ; int secs ;

} ;

Page 62: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

62

Example Using const with a Member Function

void TimeType :: Write ( ) const

// Postcondition: Time has been output in form HH:MM:SS

{ if ( hrs < 10 )

cout << ‘0’ ;

cout << hrs << ‘:’ ;

if ( mins < 10 )

cout << ‘0’ ;

cout << mins << ‘:’ ;

if ( secs < 10 )

cout << ‘0’ ;

cout << secs ;

}

Page 63: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

63

Separate Compilation and Linking of Files

timetype.h

client.cpp timetype.cpp

client.obj

client.exe

timetype.obj

Compiler Compiler

Linker

#include “timetype.h”

implementation file

specification file

main program

Page 64: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Projects

Many program files (nodes) compiled linked

as one executable (.exe)

Project files have .dsw extensions

The project name will be the executable name

Page 65: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Creating a MS VC++ Project File -> New Click on Projects Tab Select Target Type:

Win 32 Console Application Enter Project Name

(becomes name of workspace folder) Modify the workspace folder’s path to r:\.. Select empty project Click OK (new folder will be created on r:) Debug Subfolder created for .obj and .exe

Page 66: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Adding Source Code to a MSVC++ Project

To add new source code file to currently active project:

Select File -> New Click on Files tab Select C++ Source File as the file type Enter File name Modify, if necessary, the file’s folder path Click OK

Page 67: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

Adding Existing Files to a MSVC++ Project

To add new source code file(s) to currently active project:

Select File View in Workspace Pane (LHS) Right Click Source Files Folder Select “Add files to Folder” Browse and select files Click OK

Page 68: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

68

#define Directive

Page 69: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

69

often several program files use the same header file containing typedef statements, constants, or class type declarations--but, it is a compile-time error to define the same identifier twice

this preprocessor directive syntax is used to avoid the compilation error that would otherwise occur from multiple uses of #include for the same header file

#ifndef Preprocessor_Identifier

#define Preprocessor_Identifier . . .

#endif

Avoiding Multiple Inclusion of Header Files

Page 70: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

70

Example Using Preprocessor Directive #ifndef

// timetype .h FOR COMPILATION THE CLASS DECLARATION IN

// SPECIFICATION FILE FILE timetype.h WILL BE INCLUDED ONLY ONCE

#ifndef TIME_H

#define TIME_H // timetype .cpp // client.cpp

// IMPLEMENTATION FILE // Appointment programclass TimeType{ #include “timetype.h” #include “timetype.h”

public: . . . . . . int main ( void )

{

private: . . .

. . . }

} ;

#endif

Page 71: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

71

Constructors

Page 72: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

72

Class Constructors

a class constructor is a member function whose purpose is to INITIALIZE the private data members of a class object

the name of a constructor is always the name of the class, and there is no return type for the constructor

Page 73: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

73

Class Constructors

a class may have several constructors with different parameter lists. A constructor with no parameters is the default constructor

a constructor is implicitly invoked when a class object is declared--if there are parameters, their values are listed in parentheses in the declaration

Page 74: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

74

Specification of TimeType Class Constructors

class TimeType // timetype.h{public : // 7 function members

TimeType ( int initHrs , int initMins , int initSecs ) ; // constructor TimeType ( ) ; // default constructor

void Set ( int hours , int minutes , int seconds ) ;void Increment ( ) ;void Write ( ) const ;bool Equal ( TimeType otherTime ) const ; bool LessThan ( TimeType otherTime ) const ;

private : // 3 data members

int hrs ; int mins ; int secs ;

} ;

Page 75: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

75

Implementation of TimeType Default Constructor

TimeType :: TimeType ( )

// Default Constructor

// Postcondition:

// hrs == 0 && mins == 0 && secs == 0

{

hrs = 0 ;

mins = 0 ;

secs = 0 ;

}

Page 76: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

76

Implementation of Another TimeType Class Constructor

TimeType :: TimeType ( /* in */ int initHrs,

/* in */ int initMins,

/* in */ int initSecs )

// Constructor

// Precondition: 0 <= initHrs <= 23 && 0 <= initMins <= 59

// 0 <= initSecs <= 59

// Postcondition:

// hrs == initHrs && mins == initMins && secs == initSecs

{

hrs = initHrs ;

mins = initMins ;

secs = initSecs ;

}

Page 77: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

77

Automatic invocation of constructors occurs

TimeType departureTime ; // default constructor invoked

TimeType movieTime (19, 30, 0 ) ; // parameterized constructor

departureTime movieTime

Private data:

hrs

mins

secs

Set

Increment

Write

LessThan

Equal

0

0

0

Private data:

hrs

mins

secs

Set

Increment

Write

LessThan

Equal

19

30

0

Page 78: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

78

Why Objects?Why Objects Anyway? Object-oriented programming doesn't fundamentally add much (it doesn't lead to much

shorter programs) But, it is a style more appropriate to human psychology. Thesis: Humans as part of their basic function are highly adept at recognizing and

interacting with everyday objects. Everyday objects: Things we encounter everyday

Properties: active: not fully controlled by us, with internal evolving state. communicative: we can "send messages". encapsulated: some of the properties are not visible (though we can learn some of it

by sending messages) nested: complex objects have many object components (which in turn have object

components etc) uniquely named (more or less) Objects in OOP (Object-Oriented Programming) also have all of these features.

Conclusion: It is thus good to have programs create entities like these objects we are familiar with.

Page 79: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

79

See TimeTestwConstructor.dsw

Page 80: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

80

Microsoft Visual C++ Project Files (Keepers)

.dsp Project file .dsw Workspace file .exe Executable program

Page 81: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

81

Microsoft Visual C++ Temporary Files

Many are large and can be removed! .ilk Incremental link file .pch Precompiled header .pdb Precompiled debugging info .idb Incremental debug info .ncb Supports viewing classes .opt Workspace configuration .plg Build log file .obj Machine code translations

Page 82: Chapter 11 Structured Types, Data Abstraction and Classes Dale/Weems/Headington

82


Recommended