intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Lecture note Data visualization - Chapter 14

Chia sẻ: Minh Nhật | Ngày: | Loại File: PPTX | Số trang:26

12
lượt xem
1
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

This chapter presents the following content: Introduction to inheritance, inheritance in C++, IS-A relationship, polymorphism in inheritance, classes in inheritance, visibility rules, constructor and base class, adding members.

Chủ đề:
Lưu

Nội dung Text: Lecture note Data visualization - Chapter 14

  1. Lecture 14 
  2. Recap  Introduction to Inheritance  Inheritance in C++ IS­A Relationship  Polymorphism in Inheritance Classes in Inheritance Visibility Rules  Constructor and Base Class Adding Members
  3. Overriding a Method  Methods can be override from the base class in the  derived class by simply providing a derived class method  with the same signature  A derived class method must have the same or  compatible return type Sometimes it is required to invoke the derived class  method to the base class method to augment a base class  method rather than doing something entirely different.  This is known as partial overriding The scope operator can be used to call a base class  method
  4. Example class Workaholic : public Worker { public : void dowork( ) { Worker::doWork( ); // Work like a Worker drinkCof fee ( ) ; // Take a break Worker::doWork( ); // Work like a Worker some more
  5. Static and Dynamic Binding  Example Code 1 Worker w; 2 Workaholic wh; 3 . . . 4 w. doWork ( ) ; wh. doWork ( ) ; The above code illustrates the fact that we can declare  Worker and Workaholic objects in the same scope  because the compiler can deduce which dowork method to  apply w is a Worker and wh is a Workahol ic, so the 
  6. Example  1  Worker *wptr; 2  cin  >> x; 3  if  (x !=  0 ) 4   wptr =new Workaholic  ( ); 5   else 6   wptr= new Worker  ( ); 7 8   ……
  7. Explanation of Example  If x is zero, we create a Worker object; otherwise, we  create a Workaholic object Recall that, as a Workaholic IS­A Worker, a Workaholic  can be accessed by a pointer to a Worker Any method that we might call for Worker will have a  meaning for Workaholic objects Public inheritance automatically defines a type conversion  from a pointer to a derived class to a pointer to the base  class We can declare that wptr is a pointer to the base class 
  8. Continued…. The decision about which dowork to use can be made at  compile time or at run time If the decision is made at compile time, worker's dowork  must be used  because that is the type of *wptr at compile  time If wptr is actually pointing at Workaholic, this decision is  wrong. Because the type of object that wptr is actually  pointing at can be determined only as the program runs,  this decision must be made at run time A run­time decision to apply the method corresponding to  the actual referenced object is called dynamic binding
  9. Continued…. However a run­time decision incurs some run­time  overhead because it requires that the program maintain  extra information and that the compiler generate code to  perform the test This overhead was once thought to be significant  Although other languages such as Smalltalk and  Objective C use dynamic binding by default, C++ does  not
  10. Virtual Function A virtual function uses dynamic binding if a compile­time  binding decision is impossible to make  A nonvirtual function will always use static binding The default is that functions are nonvirtual. This condition  is unfortunate because we now know that the overhead is  relatively minor As a result, a nonvirtual function should be used only  when the function is invariant over the inheritance  hierarchy
  11. Continued…. Virtualness is inherited, so it can be indicated in the base  class Thus if the base class declares that a function is virtual the  decision can be made at run time; otherwise, it is made at  compile time For example In the exception class, the what method is virtual. The  derived classes require no further action to have dynamic  binding apply for what method calls
  12. Continued…. In last example code of Work class, doWork is called if it  is declared as virtual If dowork is not virtual in the Worker class, but is later  made virtual in Workaholic, then accesses through  pointers and references to Worker will still use static  binding To make a run­time decision, the keyword virtual  have to  place at the start of the dowork declaration in the Worker  class interface as  class Worker
  13. Summarizing Topic  Static binding is used by default Dynamic binding is used for virtual functions if the  binding cannot be resolved at compile time However, a run­time decision is needed only when an  object is accessed through a pointer or reference to a base  class
  14. Types of Member Function  Three types of member function Non­virtual function Virtual function Pure virtual function 
  15. Non­virtual Function Overloading is resolved at compile time To ensure consistency when pointers to objects are used We generally use a non­virtual method only when the  function is invariant over the inheritance hierarchy  Constructors are always non­virtual
  16. Virtual Function Overloading is resolved at run time The base class provides a default implementation that  may be overridden by the derived classes Destructors should be virtual
  17. Pure Virtual Function  Overloading is resolved at run time The base class provides no implementation and is abstract The absence of a default requires either that the derived  classes provide an implementation or that the derived  classes themselves be abstract
  18. Abstract Method An abstract method is declared in the base class It always defined in the derived class It says (in the base class), what all class objects in the  hierarchy can do and must eventually implement It does not provide a default implementation, so each  derived class must provide its own implementation
  19. Abstract Class  A class that has at least one abstract method is called an  abstract class The behavior of an abstract class is not completely  defined, that’s why  abstract classes can never be  instantiated When a derived class fails to override an abstract method  with an implementation, the method remains abstract in  the derived class  As a result, the derived class remains abstract, and the  compiler reports an error if an attempt to instantiate the  abstract derived class is made
  20. Constructor and Destructor   Virtual or Not­Virtual? Constructors are never virtual  Destructors should always be made virtual if they are  being used in a base class and should be non­virtual  otherwise
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
17=>2