送孟浩然之廣陵 ~李白 故人西辭黃鶴樓, 煙花三月下揚州。 孤帆遠影碧空盡, 惟見長江天際流。.

Slides:



Advertisements
Similar presentations
Constructor. 2 constructor The main use of constructors is to initialize objects. A constructor is a special member function, whose name is same as class.
Advertisements

F UNCTION O VERLOADING Chapter 5 Department of CSE, BUET 1.
Chapter 7: User-Defined Functions II
Destructors Math 130 Lecture # xx Mo/Da/Yr B Smith: New lecture for 05. Use this for evolving to Java B Smith: New lecture for 05. Use this for evolving.
1 Pointers A pointer variable holds an address We may add or subtract an integer to get a different address. Adding an integer k to a pointer p with base.
. Copying, casting, and more. Example: MyString u Lets put our knowledge of C++ classes to use u Define a class to represent a string u Replace all the.
11 Values and References Chapter Objectives You will be able to: Describe and compare value types and reference types. Write programs that use variables.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 19 Clicker Questions November 3, 2009.
Modular Programming Chapter Value and Reference Parameters t Function declaration: void computesumave(float num1, float num2, float& sum, float&
1 Chapter 7 Defining Your Own Data Types. 2 What Is a struct ?  A structure is a user-defined type You define it using the keyword struct so it is often.
Overview of Previous Lesson(s) Over View  Operator Overloading:  Operator overloading is a very important capability, it enables to make standard C++
C++ Programming: From Problem Analysis to Program Design, Fifth Edition, Fifth Edition Chapter 7: User-Defined Functions II.
Copyright  Hannu Laine C++-programming Part 1 Hannu Laine.
1 Chapter 8 Destructor & Operator Overloading. 2 Destructor  A destructor is a function that is called when an object is no longer required. A constructor.
1 Overloading Overloading allows a function or operator to have a different meaning depending on the type of objects it is used on. Examples: operator+
Overloading Operator MySting Example. Operator Overloading 1+2 Matrix M 1 + M 2 Using traditional operators with user-defined objects More convenient.
Concordia University Department of Computer Science and Software Engineering Click to edit Master title style ADVANCED PROGRAM DESIGN WITH C++ Part 9:
Object Oriented Programming Elhanan Borenstein Lecture #3 copyrights © Elhanan Borenstein.
Lecture 3 Classes, Structs, Enums Passing by reference and value Arrays.
CPSC 252 The Big Three Page 1 The “Big Three” Every class that has data members pointing to dynamically allocated memory must implement these three methods:
CMSC 202, Version 3/02 1 Copy Constructors and Overloaded Assignment.
Chapter 1 C++ Basics Review (Section 1.4). Classes Defines the organization of a data user-defined type. Members can be  Data  Functions/Methods Information.
Overview of Previous Lesson(s) Over View 3  CLR Programming  Common Language Runtime (CLR) is a programming, that manages the execution of programs,
Functions CMSC 202. Topics Covered Function review More on variable scope Call-by-reference parameters Call-by-value parameters Function overloading Default.
1 Ugly Realities The Dark Side of C++ Chapter 12.
Function Parameters and Overloading Version 1.0. Topics Call-by-value Call-by-reference Call-by-address Constant parameters Function overloading Default.
Secure Coding Rules for C++ Copyright © 2016 Curt Hill
Operator Overloading CS 3370 – C++ Chapter 14.
Yan Shi CS/SE 2630 Lecture Notes
Chapter 1.2 Introduction to C++ Programming
Learning Objectives Pointers as dada members
Chapter 1.2 Introduction to C++ Programming
Chapter 7: User-Defined Functions II
Chapter 1.2 Introduction to C++ Programming
論語 先進第十一 暮春者,春服既成 冠者五六人,童子六七人 浴乎沂,風乎舞雩,詠而歸 ㄧˊ 〔~河〕水名,源出中國山東省,至江蘇省入海。
Chapter 1.2 Introduction to C++ Programming
Overloading Operator MySting Example
Bill Tucker Austin Community College COSC 1315
Pointers and Pointer-Based Strings
Lecture 6 C++ Programming
This pointer, Dynamic memory allocation, Constructors and Destructor
The dirty secrets of objects
group work #hifiTeam
Object Oriented Programming COP3330 / CGS5409
understanding memory usage by a c++ program
Chapter 15 Pointers, Dynamic Data, and Reference Types
Operator Overloading; String and Array Objects
Advanced Program Design with C++
Operator overloading Dr. Bhargavi Goswami
If Statements.
CISC/CMPE320 - Prof. McLeod
Pointers and Pointer-Based Strings
CS410 – Software Engineering Lecture #5: C++ Basics III
COP 3330 Object-oriented Programming in C++
Pointers and dynamic objects
A Deeper Look at Classes
CMSC 202 Lesson 6 Functions II.
Pointers and References
Class rational part2.
CS 144 Advanced C++ Programming March 21 Class Meeting
登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。
登金陵鳳凰臺 ~李白 鳳凰臺上鳳凰遊, 鳳去臺空江自流。 吳宮花草埋幽徑, 晉代衣冠成古丘。 三山半落青山外, 二水中分白鷺洲。
黃鶴樓 ~ 崔顥 昔人已乘黃鶴去, 此地空餘黃鶴樓。 黃鶴一去不復返, 白雲千載空悠悠。 晴川歷歷漢陽樹, 芳草萋萋鸚鵡洲。
Chapter 8 (Part 2) Destructor & Operator Overloading (P.331)
Video: The Sound of Raining
Chapter 8 Destructor (P.323) & Operator Overloading
Reference variables, pass-by-reference and return-by-reference
Copy Constructors and Overloaded Assignment
四時讀書樂 (春) ~ 翁森 山光照檻水繞廊,舞雩歸詠春風香。 好鳥枝頭亦朋友,落花水面皆文章。 蹉跎莫遣韶光老,人生唯有讀書好。
Presentation transcript:

送孟浩然之廣陵 ~李白 故人西辭黃鶴樓, 煙花三月下揚州。 孤帆遠影碧空盡, 惟見長江天際流。

Chapter 8 (Part 2) Destructor & Operator Overloading

Sample Code of CRational Addition #include <iostream> using namespace std; // See P.97 class CRational { public: int numerator; // 分子 int denominator; // 分母 CRational(int p=0, int q=1) : numerator(p), denominator(q) { if (q==0) cout << "Error! The denominator cannot be 0.\n"; exit(1); } void Print() //印出分子&分母 cout << numerator; if (denominator != 1) cout << "/" << denominator; void Add(CRational a, CRational b) //將兩分數相加 int c; int d; c = a.numerator*b.denominator+a.denominator*b.numerator; d = b.denominator*a.denominator; cout << c; // Simply print out, so you cannot if(d != 1) // add three rational numbers cout << "/" << d ; };

Another Example class CRational { public: int numerator; // 分子 int denominator; // 分母 CRational(int p=0, int q=1){ numerator=p; denominator=q; } CRational Add(CRational data_a,CRational data_b){ CRational temp; temp.numerator = data_a.numerator*data_b.denominator+ data_b.numerator*data_a.denominator; temp.denominator = data_a.denominator*data_b.denominator; return temp; }; int n = data_a.numerator*data_b.denominator+ data_b.numerator*data_a.denominator; int d = data_a.denominator*data_b.denominator; return CRational(n, d); return CRational( data_a.numerator*data_b.denominator+ data_b.numerator*data_a.denominator, data_a.denominator*data_b.denominator);

Call the member function from main() int main(){ int input_n,input_d; while(1){ printf("please input two Rational\n"); printf("the a's numerator is:"); scanf("%d",&input_n); printf("the a's denominator is:"); scanf("%d",&input_d); CRational a(input_n,(input_d==0?1:input_d)); printf("the b's numerator is:"); printf("the b's denominator is:"); CRational b(input_n,(input_d==0?1:input_d)); CRational c; c.Add(a,b); c.Print(); } return 0; You should handle this in the constructor, not here for every input.

How do we calculate d = a + b + c? For c = a + b: c.Add(a, b); For d = a + b + c: temp.Add(a,b); d.Add(temp,c); For e = a + b + c + d: temp1.Add(a, b); temp2.Add(c, d); e.Add(temp1, temp2); After we declare a class CRational, it will be more natural if we can simply write c = a + b instead of c.Add(a,b)? Can we do that?

Operator Overloading Operator overloading is a very important capability. It allows you to make standard C++ operators, such as +, -, * and so on, work with objects of your own data types. We want to write if (box1 > box2) instead of if (IsGreaterThan(box1, box2)) Let us recall some background of function overloading (Chapter 6). 4/15

Function Overloading Function overloading allows you to use the same function name for defining several functions as long as they each have different parameter lists. When the function is called, the compiler chooses the correct version according to the list of arguments you supply. The following functions share a common name, but have a different parameter list: int max(int array[], int len); long max(long array[], int len); double max(double array[], int len);

Ex6_07.cpp on P.311 Three overloaded functions of max() In main(), C compiler inspect the argument list to choose different version of functions.

Signature The signature of a function is determined by its name and its parameter list. All functions in a program must have unique signatures The following example is not valid overloading double max(long array[], int len); long max(long array[], int len); A different return type does not distinguish a function, if the signatures are the same.

Implementing an Overloaded Operator class CBox { public: bool operator> (CBox& aBox) const; } The word operator here is a keyword. You declare the operator>() function as const because it doesn’t modify any data members of the class. (P.393)

Using an Overloaded Operator if (box1 > box2) cout << “box1 is greater than box2”; if (box1.operator>(box2)) V

Ex8_03.cpp on P.449 bool CBox::operator> (CBox& aBox) const { return this->Volume() > aBox.Volume(); } The left operand is defined implicitly by the pointer this. The basic > operator returns a value of type int 1 for true (P.56, non-zero value as true) 0 for false. It will be automatically converted to bool.

Overloading the Assignment Operator What’s wrong with the default assignment? It simply provides a member-by-member copying process, similar to that of the default copy constructor. They suffer from the same problem (P.442), when some data members are allocated dynamically.

Fixing the Problem CMessage& operator= (const CMessage& aMess) { // buffer = string1; // Release memory for 1st operand delete [] pmessage; pmessage = new char [ strlen(aMess.pmessage) + 1]; // Copy 2nd operand string to 1st strcpy(this->pmessage, aMess.pmessage); // Return a reference to 1st operand return *this; }

Why Do You Need to Return Something? Consider this statement motto1 = motto2 = motto3; The assignment operator is right-associative, so it translates into motto1 = (motto2.operator=(motto3)); motto1.operator=(motto2.operator=(motto3)); You must at least return a CMessage object.

Why Do You Need to Return a Reference? Consider another example (motto1 = motto2) = motto3; This translates into (motto1.operator=(motto2)) = motto3; If the return type is merely CMessage instead of a reference, a temporary copy of the original object is returned. Then you are assigning a value to a temporary object! Make sure that your return type is CMessage&.

Check Addresses, If Equal The first thing that the operator function does is to delete the memory allocated to the first object (See P.455 again), and reallocate sufficient memory to accommodate the new string. What happens to this statement? motto1 = motto1 Add this checking: (P.457) if (this == &aMess) return *this;

Overloading the Addition Operator Suppose we define the sum of two CBox object as a CBox object which is large enough to contain the other two boxes stacked on top of each other. See Figure 8-4. CBox CBox::operator+(const CBox& aBox) const { return CBox( m_Length > aBox.m_Length ? m_Length : aBox.m_Length, m_Width > aBox.m_Width ? m_Width : aBox.m_Width, m_Height + aBox.m_Height); } Ex8_06.cpp on P.461

Using Classes We want to pack candy into candy boxes, and pack candy boxes to cartons (紙板箱). The objects candy, candybox, carton, all belong to the CBox class. We are packing CBox objects into other CBox objects.

Basic Operations of the CBox Class Calculate the volume of a CBox Volume() Compare the volumes of two CBox objects to determine which is the larger. operator>() Compare the volume of a CBox object with a specified value We have this for the > operator (P.452) Add two CBox object to produce a CBox object operator+() Multiply a CBox object by an integer to provide a CBox object Determine how many CBox objects of a given size can be packed in another CBox object of a given size. This is effectively division, so you could implement this by overloading the / operator. Determine the volume of space remaining in a CBox object after packing it with the maximum number of CBox objects of a given size. Wasted spaced.

The Multiply Operation If n is even, stack the boxes side-by-side by doubling the m_Width value and only multiplying the m_Height value by half of n. (P.490)

P.491 // CBox multiply operator this*n CBox operator*(int n) const { if (n % 2) return CBox(m_Length, m_Width, n*m_Height); // n odd else return CBox(m_Length, 2.0*m_Width, (n/2)*m_Height); // n even }

The Division Operation (P.492) Figure 8-7

Member Function operator/() int operator/(const CBox& aBox) { int tc1 = 0; int tc2 = 0; tc1 = static_cast<int>((m_Length / aBox.m_Length)) * static_cast<int>((m_Width / aBox.m_Width)); tc2 = static_cast<int>((m_Length / aBox.mWidth)) * static_cast<int>((m_Width / aBox.m_Length)); return static_cast<int>((m_Height/aBox.m_Height)*(tc1>tc2 ? tc1 : tc2)); }

Member Function operator%() It would be easy to check the remaining space using the functions you have already defined: // Operator to return the free volume in a packed CBox double operator%( const CBox& aBox, const CBox& bBox) { return aBox.Volume() - (aBox / bBox) * bBox.Volume(); }

Exercise Modify HW3 so that addition is implemented as operator+(). Test your implementation with calculations like a + b a + b + c + d a + a + a + a Also, try to implement operator-(), and test a – b – c – d