Module 2: User Data types #1 2000/01Scientific Computing in OOCourse code 3C59 Module 2: User defined Data Types & Operations upon them In this module.

Slides:



Advertisements
Similar presentations
Chapter 8 Technicalities: Functions, etc. Bjarne Stroustrup
Advertisements

CIT 590 Intro to Programming Classes. Schedule change The upcoming HW (HW6) is your last major Python HW. It will involve object oriented programming.
Composition CMSC 202. Code Reuse Effective software development relies on reusing existing code. Code reuse must be more than just copying code and changing.
Java Programming Chapter 3 More about classes. Why?  To make classes easier to find and to use  to avoid naming conflicts  to control access  programmers.
Slides prepared by Rose Williams, Binghamton University Chapter 13 Interfaces and Inner Classes.
CS-341 Dick Steflik Introduction. C++ General purpose programming language A superset of C (except for minor details) provides new flexible ways for defining.
© The McGraw-Hill Companies, 2006 Chapter 7 Implementing classes.
C++ fundamentals.
(c) University of Washington04-1 CSC 143 Java Inheritance Example (Review)
C++ / G4MICE Course Session 3 Introduction to Classes Pointers and References Makefiles Standard Template Library.
1 Using Classes Object-Oriented Programming Using C++ Second Edition 5.
Using Classes Object-Oriented Programming Using C++ Second Edition 5.
Programming Languages and Paradigms Object-Oriented Programming.
CSM-Java Programming-I Spring,2005 Introduction to Objects and Classes Lesson - 1.
 2003 Prentice Hall, Inc. All rights reserved. 1 Introduction to Classes and Objects Outline Introduction Classes, Objects, Member Functions and Data.
Classes Mark Hennessy Dept. Computer Science NUI Maynooth C++ Workshop 18 th – 22 nd Spetember 2006.
CMP-MX21: Lecture 6 Objects & Methods 1 Steve Hordley.
CIT 590 Intro to Programming Style Classes. Remember to finish up findAllCISCourses.py.
Chapter 9 Defining New Types. Objectives Explore the use of member functions when creating a struct. Introduce some of the concepts behind object-oriented.
Classes and Objects. Topics The Class Definition Declaring Instance Member Variables Writing Instance Member Methods Creating Objects Sending Messages.
Module 10: Simple Inheritance #1 2000/01Scientific Computing in OOCourse code 3C59 Module 10: Simple Inheritance In this module we will cover Inheritance.
© The McGraw-Hill Companies, 2006 Chapter 4 Implementing methods.
Programming in Java Unit 2. Class and variable declaration A class is best thought of as a template from which objects are created. You can create many.
Week 4 Introduction to Computer Science and Object-Oriented Programming COMP 111 George Basham.
Object-Oriented Programming in C++
Classes CS 21a: Introduction to Computing I First Semester,
Chapter 7 Objects and Classes 1 Fall 2012 CS2302: Programming Principles.
Technical Module : Pointers #1 2000/01Scientific Computing in OOCourse code 3C59 Technical Module : Pointers In this module we will cover Pointers to primitives.
Defining New Types Lecture 21 Hartmut Kaiser
Comp 249 Programming Methodology Chapter 13 Interfaces & Inner Classes Dr. Aiman Hanna Department of Computer Science & Software Engineering Concordia.
11 Working with Images Session Session Overview  Find out more about image manipulation and scaling when drawing using XNA  Start to implement.
CPSC 230 Computers and Programming I Spring 2003 Dr. Lynn Lambert.
ADTs and C++ Classes Classes and Members Constructors The header file and the implementation file Classes and Parameters Operator Overloading.
Week 4 Introduction to Computer Science and Object-Oriented Programming COMP 111 George Basham.
Classes In C++ 1. What is a class Can make a new type in C++ by declaring a class. A class is an expanded concept of a data structure: instead of holding.
Module 3: Steering&Arrays #1 2000/01Scientific Computing in OOCourse code 3C59 Module 3: Algorithm steering elements If, elseif, else Switch and enumerated.
C++ Programming Basic Learning Prepared By The Smartpath Information systems
Topic 1 Object Oriented Programming. 1-2 Objectives To review the concepts and terminology of object-oriented programming To discuss some features of.
Module 8: more on methods #1 2000/01Scientific Computing in OOCourse code 3C59 Module 8: More on methods: In this module we will cover: Overloading of.
Chapter 3 Part I. 3.1 Introduction Programs written in C ◦ All statements were located in function main Programs written in C++ ◦ Programs will consist.
Chapter 4&5 Defining Classes Copyright © 2010 Pearson Addison-Wesley. All rights reserved.
Structures and Classes Version 1.0. Topics Structures Classes Writing Structures & Classes Member Functions Class Diagrams.
Module 4: I/O and Strings #1 2000/01Scientific Computing in OOCourse code 3C59 Module 4: I/O In this module we will cover Keyboard/screen input and output.
Fall 2015CISC/CMPE320 - Prof. McLeod1 CISC/CMPE320 Today: –Review declaration, implementation, simple class structure. –Add an exception class and show.
Topic 8Classes, Objects and Methods 1 Topic 8 l Class and Method Definitions l Information Hiding and Encapsulation l Objects and Reference Classes, Objects,
Classes, Interfaces and Packages
Object Oriented Programming. OOP  The fundamental idea behind object-oriented programming is:  The real world consists of objects. Computer programs.
72 4/11/98 CSE 143 Abstract Data Types [Sections , ]
Monday, Jan 27, 2003Kate Gregory with material from Deitel and Deitel Week 4 Questions from Last Week Hand in Lab 2 Classes.
Module 7: Constructors #1 2000/2001Scientific Computing in OOCourse code 3C59 Module 7: Constructors and Destructors: In this module we will cover: Constructors.
OOP Basics Classes & Methods (c) IDMS/SQL News
Programming Fundamentals Enumerations and Functions.
CLASSES AND OBJECTS Chapter 3 : constructor, Separate files, validating data.
Module 5: I/O and Strings #1 2000/01Scientific Computing in OOCourse code 3C59 Module 5: I/O and STRINGS In this module we will cover The C++ input and.
Chapter 3 Implementing Classes
Module 9: Operator overloading #1 2000/01Scientific Computing in OOCourse code 3C59 Module 9: Operator Overloading In this module we will cover Overloading.
4 - Conditional Control Structures CHAPTER 4. Introduction A Program is usually not limited to a linear sequence of instructions. In real life, a programme.
Module 11: Polymorhism #1 2000/01Scientific Computing in OOCourse code 3C59 Module 11: Polymorphism and virtual methods In this module we will cover Polymorphism.
ENCAPSULATION. WHY ENCAPSULATE? So far, the objects we have designed have all of their methods and variables visible to any part of the program that has.
Computer Programming II Lecture 5. Introduction to Object Oriented Programming (OOP) - There are two common programming methods : procedural programming.
Module 20/21/22: The Standard Template Library
Chapter 3: Using Methods, Classes, and Objects
Packages, Interfaces & Exception Handling
Object-Oriented Programming Using C++ Second Edition
Classes and Objects.
Java-An introduction In this module we will cover The class in Java
COP 3330 Object-oriented Programming in C++
Introduction to Data Structure
Defining Classes and Methods
Software Development Techniques
Presentation transcript:

Module 2: User Data types #1 2000/01Scientific Computing in OOCourse code 3C59 Module 2: User defined Data Types & Operations upon them In this module we will cover Inadequacies of in-built data types User defined data types (classes and objects) Operations on objects (methods) Public and Private members of an object The first steps to data encapsulation

Module 2: User Data types #2 2000/01Scientific Computing in OOCourse code 3C59 Aims of the module In this module we show that the simple in-built data types are not generally convenient for representing the types of entity you find in even a simple programming situation. In general you need several integers, floats, characters...etc.. to do this in raw form would lead to excessively messy and cumbersome code. This leads us to introduce the idea of user defined data types which contain variables for all the attributes of an entity. In C++ this means the use of classes We introduce the word "object" to mean "instance of a class" We then show you how you can manipulate the member variables of such objects. However we then convince you that actually manipulating the member variables of such objects is bad news. Not only is it still cumbersome, it is fundamentally dangerous as it means the innerds of the class can then never be changed without upsetting users. To avoid this we introduce a set of functions to separate the user from the implementer. We call these “Methods of the class”. These Methods are the only things allowed to access the variables in the class. Finally we consolidate the ideas we have introduced by taking an abstract look at Data Encapsulation

Module 2: User Data types #3 2000/01Scientific Computing in OOCourse code 3C59 Student exercise - Modify the code you wrote earlier to find the angle between two vectors. -This time encapsulate the calculation of: (a) the magnitude of a a vector (b) the dot product of two vectors inside two functions. - Use these functions to simplify the code which performs the calculation of the angle between the vectors. DotProduct/ dprod2.cpp We are going to start this module with an exercise in order to make some points 2.1 Inadequacies of in-built data types

Module 2: User Data types #4 2000/01Scientific Computing in OOCourse code 3C59 The points which it is intended to illustrate are: The vectors cannot be handled as a single item -they have to be passed around as three disconnected numbers. This is cumbersome. Functions are becoming silly. The dot product already needs to have 6 arguments ! What would we do if we wanted to add a “magnitude” number to the representation of a vector?. We would have to go and edit every function to have 4 arguments per vector instead of 3!  completely un-maintainable code What would we do for an “entity” which was more complex than a vector ?

Module 2: User Data types #5 2000/01Scientific Computing in OOCourse code 3C59 Here is a good, more abstract, example: BankAccount How would we represent this of we were writing some financial software ? Well, we could just write a lot of simple data types:...but this has all the problems we have just illustrated. // One (bad) realisation of a BankAccount string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ; Entity type: BankAccount Attributes: holdersName currentBalance overdraftLimit jointAccount yearsHeld...

Module 2: User Data types #6 2000/01Scientific Computing in OOCourse code 3C59 Note: I pulled a fast one here with string holdersName ; This is a much easier way to handle strings of characters than using the in-built char variable. More on this later // One (bad) realisation of a BankAccount string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ;

Module 2: User Data types #7 2000/01Scientific Computing in OOCourse code 3C59 The problem is that we have lots of separate bits of information which just happen to be written next to each other in the file. It is clear that in any sensible language you need a way of referring to the whole collection with a single variable name. What you really need is a variable of type : BankAccount string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ; // Declare two bank accounts in some hypothetical language BankAccount billGates ; BankAccount peterClarke ; …some code to empty billGates into peterClarke……… all this needs to be inside the BankAccount

Module 2: User Data types #8 2000/01Scientific Computing in OOCourse code 3C User defined Data Types (classes) In any sensible language you can define “User Defined Data Types” to represent the “Entities” in your problem Entity type: BankAccount Attributes: holdersName currentBalance overdraftLimit jointAccount yearsHeld... “Entity” is the abstract notion of something in your problem “Data Type” is a representation of this in some system (here a language) Loosely:

Module 2: User Data types #9 2000/01Scientific Computing in OOCourse code 3C59 Here is how: // C++ code to define a BankAccount class class BankAccount { public: string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ; } ; This is called a “class” The variables inside it are called “class member variables” If you include this definition in your program, you can now use BankAccount as if it were an in-built data type

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Aside: note the keyword public: // C++ code to define a BankAccount class class BankAccount { public: string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ; } ; This means that all of the variables following it will be “publicly available” for any other bit of code to use. At this point this wont mean much to you. Just ignore it for now. All will become clear very shortly.

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Here is an example of how you declare some instances of the BankAccount class, and access the “members variables” // Declare two accounts BankAccount billGates ; BankAccount peteClarke ; // Print out my balance float balance ; balance = peteClarke.currentBalance ; std::cout << “They don’t pay me enough“ << balance ; // Do a transfer peteClarke.currentBalance = billGates.currentBalance; billGates.currentBalance = 0 ; Note the use of the. to refer to a “member” of a BankAccount This is how you manipulate members of a BankAccount This is how you make two instances of the BankAccount class

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Here is an example of how you would pass a "BankAccount" to a function // Declare a bank account BankAccount peteClarke ; // Use a funtion to make a deposit in it float amount = 500 ; makeDeposit( peteClarke, amount ) ;.... Note that you treat the BankAccount just like you would an int or float // function to make a deposit in a BankAccount makeDeposit( BankAccount accountToUse, float amt ) { accountToUse.currentBalance += amt ; return ; }... and here is the function itself: The arguments are declared just as normal

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Student exercise -Write a class to represent the “3-vector” we have used in previous examples - Call it ThreeVector -Modify the code you have written earlier (to find the angle between two vectors) to use the ThreeVector class you have defined. - This will require changing the arguments of any functions you have written to accept instances of the new class type. util/ ThreeVector_firstgo.h DotProduct/ dprod3.cpp

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Note on organisation of code for classes #include “ThreeVector.h” #include “BankAccount.h” ~~~~~~~~ ThreeVector vec ; ~~~~~~~~ BankAccount acc ; “main” file class ThreeVector { ~~~~~~~~~~ } ; ThreeVector.h definitions included in main file whenever you need these classes class BankAccount { ~~~~~~~~~~ } ; BankAccount.h keep these in separate files for ease of organisation and maintenance can be re-used in many different applications

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C /OOCourse /util /DotPoduct /BankAccount /ComptonAnalysis /ComptonMC /Complex / Put dprod3.cpp it here then include #include "../ThreeVector.h" Put ThreeVector.h here

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 We are so happy with what we have done that we are going to invent a new word to celibrate: object When we say we have "we have made an instance of a class" we will say we have made an object

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 // Instances of types BankAccount peteClarke ; The class is the type Just like you would use int or float as a type. The object is an instance of that class The object can hold values of its internal member variables

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 We are going to spend a little time at this point to ensure that you fully understand what has gone on in the last section.

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 We are now going togo much further We want to separate the user from the details of the “member variables” in a class definition. We are going to INSIST that a user only interacts with an object via a set of specially written functions which perform all the things we ever need to do to it. Opposite you see some functions to operate on BankAccount objects 2.3 Operations on objects using methods class: BankAccount Member variables: holdersName currentBalance overdraftLimit jointAccount yearsHeld Methods: initialise( ) availableFunds( ) deposit( ) withdrawl( ) printStatus( )

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 We could do this just like you did in the previous example, i.e.  just write a plain old function for each operation  each such function would be passed a BankAccount just like you passed a ThreeVector to dotProduct(..) However if we did this, these functions would really be disconnected from the class. In other words it could only be by “agreement” that users would use them to operate on the class.

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Instead we are now going to take a step which you will not have seen in any procedural language:  We are going to place the functions inside the definition of the class itself. Just like we had “class member variables” we now will have “class member functions” you could put this another way and say that the functions are going to “belong” to the class. These special functions are called “member functions” or equivalently “methods”

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Here is how you write member functions (methods) as part of a class: // C++ code to define a BankAccount class // Now with two member functions (methods) added class BankAccount { public: string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ; void withdrawl( ) {.... write function code here... } float availableFunds( ) {.... write function code here.... }.... other methods similarly written.... } ; This method is written just like a normal function, but inside the body of the class

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 float availableFunds( ) { // This is a method of BankAcount // Its function is to return the funds which are // available for use by the account holder float funds ; funds = currentBalance + overdraftLimit ; return funds ; } Here are the details of a trivial method: availableFunds( ) It doesnt need any arguments. The method uses the member variables of the BankAccount

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 void withdrawl( float amount ) { // This is a method of BankAcount // //Its function is to make a withdrawal if //this is possible. // check whether this withdrawal can be made float limit ; limit = currentBalance+overdraftLimit ; if( amount < limit ) { // Ok to withdraw currentBalance -= amount ; } else { // Not enough money - tough luck } return ; } Here is the withdrawl( ) method Note the if{} and else{} statements, and the use of the < operator. We will return to these later in more detail. This is how you declare that it doesn’t return anything

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Student exercise - A partially written file is provided for you called: BankAccount_for_students.h this includes the methods we have already looked at. Copy this file and rename it to BankAccount.h - Complete this file by adding the other methods listed earlier, i.e. initialise(... ) deposit(... ) printStatus( ) - Modify the withdrawl( ) method to return a bool variable (true or false) to indicate whether the withdrawl was successful. BankAccount/ BankAccount_inline.h

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C /OOCourse /util /DotPoduct /BankAccount /ComptonAnalysis /ComptonMC /Complex / Put it here

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Now we have written the BankAccount.h to include some methods, we will see how to use them in a program 2.4 Using methods

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 #include "BankAccount.h" // Declare a BankAccount object BankAccount newAccount ; // make a deposit in the account float amount = 750 ; newAccount.deposit( amount ) ; // Find out available funds float funds ; funds = newAccount.availableFunds( ) ; std::cout << " The balance is " << funds; You pass the argument it needs in the normal way You invoke the deposit method on the newAccoount object, using the. operator

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Note a key concept here: // Declare a BankAccount object BankAccount newAccount ; // make a deposit in the account float amount = 750 ; newAccount.deposit( amount ) ; This syntax is telling the object ( newAccount ) to do something to itelf ( deposit( ) an amount ) When the deposit method is run it knows which member variables to operate on  those of the particular object for which it has been called It is as if each object has its own personal set of functions which operate only upon its "internal" member variables

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 In other words: // Declare an account BankAccount newAccount1 ; BankAccount newAccount2 ; // make a deposit in account 1 float amount = 750 ; newAccount1.deposit( amount ) ; // make a deposit in account 2 amount = 500 ; newAccount2.deposit( amount ) ; This invokes the deposit method to operate on the member variables of the first account object. This invokes the deposit method to operate on the member variables of the second account object

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Pictorially: // Declare an account BankAccount newAccount1 ; BankAccount newAccount2 ; // make a deposit in account 1 float amount = 750 ; newAccount1.deposit( amount ) ; // make a deposit in account 2 amount = 500 ; newAccount2.deposit( amount ) ;

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Private study Make sure you are familiar with what is going on in this example: - a class written in a file and #included -making variables which are instances of the class - using methods to operate on each instance YOU MUST SEEK FURTHER EXPLANATION IF YOU ARE IN DOUBT AT THIS POINT BankAccount/ bamain1.cpp Look in the following file for a more complete example

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C Public -vs- Private members We are nearly, but not quite there with the earlier stated goal: "We are going to INSIST that a user only interacts with the contents of a class via a set of specially written functions which perform all the things we ever need to do to it." Up to this point nothing stops the user accessing the member varibles directly, i.e: // make a withdrawl from the account float amount = 750 ; newAccount.currentBalance -= amount ;... rather than // make a withdrawl from the account float amount = 750 ; newAccount.withdrawl( amount ) ; Philosophy aside: Why DO I care?

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 C++ allows you to declare member variables to be "private" so that ONLY the methods of the class can alter them

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Here is how you make things in the class private class BankAccount { private: string holdersName ; float currentBalance ; float overdraftLimit ; int jointAccount ; int yearsHeld ; public: float initialise( ) {.... } float availableFunds( ) {.... }.... other methods.... } ; Anything following this can only be used by methods of the class Anything following this can be used by anyone outside the class

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 // make a withdrawl from the account float amount = 750 ; newAccount.currentBalance -= amount ; Only this WILL WORK // make a withdrawl from the account float amount = 750 ; newAccount.withdrawl( amount ) ; Now this WILL NOT work (the compiler will not allow it)

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C The first steps toward “Data Encapsulation” Up to this point we have been skirting around one of the fundamental concepts of OO programming - that of “Data Encapsulation” In this section we will spend a few moments consolidating this idea. ( don’t worry if you find this a bit abstract at present ! )

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 This is a first look at the idea of an “object”  something which encapsulates its “state” internally,  only allows users to interact with it through a public interface Private data Members Private Methods Public Methods The variables which define the “state” of the object are not accessible to a user. They are “private” There may be some “private” methods for internal use only There are a set of “public” Methods. These are the only way a user may interact with the object User program Calls public Methods

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Why bother with all this ? It separates the user from the implementer  the implementer can do what they like inside, and even change it later  none of this will affect a user provide the interface is maintained  re-use  easier maintenance....well.. some of these things anyway Protective membrane

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 We have developed a (not very interesting) example: holdersName currentBalance overdraftLimit... print Status... initialise withdrawaldeposit available Funds BankAccount

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 You have to get into the mode of thinking about software in terms of objects You have to ask: "What services should an object provide" You should not care how it does it, nor how it represents itself internally In other words you must get away from the habit of knowing or caring what the internal member variables are.

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Student exercise -Write the ThreeVector class properly - You should include the following methods (and any others you think fit) initialise( ) - to initialise the data members to values specified in arguments. magnitude( ) - to return the magnitude of the vector dotProduct( ) - form the dot product between the vector and another one supplied in an argument. angle( ) - to return the angle between the vector and another one supplied in an argument. dump( ) - to print out some suitable info on the vector contents Modify your dot product code to use all these methods, particularly the initialise() method. The code is much neater now !!!!!! util/ ThreeVector_ secondgo.h DotProduct/ dprod4.cpp

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Summary of Module 2: User defined Data Types & Operations upon them Inadequacies of in-built types limited use problems generally contain abstract entities difficulty in referring to a single instance difficulty in passing a group of variables as arguments User defined data types classes declaration of instances of a class (object)

Module 2: User Data types # /01Scientific Computing in OOCourse code 3C59 Operations on object member variables: access to members of an object simple manipulations of members Operations on objects via methods Use of “Methods” to hide the implementation of an object from a user First steps toward data encapsulation Consolidation of the ideas of: Object consisting of “state” and “Methods” to use/change it “private Members”, I.e. hiding data members from user “public Methods”, I.e the things a user program may use