C++实现动态绑定代码分享

C++实现动态绑定代码分享

#include <iostream>
#include<string>
using namespace std;
class BookItem
{
private:
  string bookName;
  size_t cnt;
public:
  BookItem(const string&s,size_t c,double p):
    bookName(s),cnt(c),price(p)
    {}
  ~BookItem(){}
protected:
  double price;
public:
  double bookPrice()
  {
    return this->price;
  }
  string getBookName()
  {
    return this->bookName;
  }
  size_t getBookCount()
  {
    return this->cnt;
  }
  virtual double money()
  {
     return cnt*price;
  }
  virtual void costMoney()
  {
    cout<<money()<<endl;
  }
};
class BookBatchItem:public BookItem
{
private:
  string bookName;
  size_t cnt;
public:
  BookBatchItem(const string&s,size_t c,double p,double discountRate):
    BookItem(s,c,p),cnt(c),discount(discountRate)
    {}
  ~BookBatchItem(){}
private:
  double discount;
public:
  double money()
  {
    if(cnt>=10)
      return cnt*price*(1.0-discount);
    else
      return cnt*price;
  }
  void costMoney()
  {
    cout<<money()<<endl;
//    cout<<cnt<<endl;
//    cout<<price<<endl;
//    cout<<discount<<endl;
//    cout<<"..."<<endl;
  }
};
int main()
{
  BookItem b1("Uncle Tom's house",11,12.5);
  b1.costMoney();
  BookBatchItem b2("Gone with wind",11,12.5,0.12);
  b2.costMoney();
  BookItem* pb=&b1;
  pb->costMoney();
  pb=&b2;
  pb->costMoney();
  return 0;
}

只有采用“指针->函数()”或“引用.函数()”的方式调用C++类中的虚函数才会执行动态绑定,非虚函数并不具备动态绑定的特征,不管采用任何方式调用都不行。

下面代码中,一个java或者C#的程序员容易犯的一个错误。

 class Base
 {
 public:
   Base() { p = new char ; }
   ~Base() { delete p; }
 private:
   char * p ;
 };

 class Derived:public Base
 {
 public:
   Derived() { d = new char[10] ; }
   ~Derived() { delete[] d; }
 private:
   char * d ;
 };

 int main()
 {
   Base *pA = new Derived();
   delete pA ;

   Derived *pA = new Derived();
   delete pA ;
 }

代码中:
执行delete pA时,直接执行~Base析构函数,不会执行~Derived析构函数的,原因在于析构函数不是虚函数。
执行delete pB时,先执行~Derived()然后再执行~Base()。
相比之下,java和C#中,所有的函数调用都是动态绑定的。

关于C++的成员函数调用与绑定方式,可以通过下面的代码测试:

 class Base
 {
 public:
   virtual void Func() { cout<<"Base"<<endl; }
 };

 class Derived:public Base
 {
 public:
   virtual void Func() { cout<<"Derived"<<endl; }
 };

 int main()
 {
   Derived obj;
   Base * p1 = &obj;
   Base & p2 = obj;
   Base obj2 ;

   obj.Func() ;  //静态绑定,Derived的func
   p1->Func();   //动态绑定,Derived的func
   (*p1).Func();  //动态绑定,Derived的func
   p2.Func();   //动态绑定,Derived的func
   obj2.Func();  //静态绑定,Base的func

   return 0 ;
 }

可以看出“对象名.函数()”属于静态绑定,当然,使用指针转换为对象的方式应该属于指针调用那一类了,至于“类名::函数()”毫无疑问属于静态绑定。

(0)

相关推荐

  • asp.net checkbox 动态绑定id GridView删除提示

    asp.net checkbox 动态绑定id 复制代码 代码如下: <input id='<%# "courseNo"+Eval("courseNo") %>' type="checkbox" onclick="return Click()"/> GridView删除提示 复制代码 代码如下: <div id="del" onClick="return confir

  • Chrome扩展页面动态绑定JS事件提示错误

    问题描述: 当开发Chrome扩展时,页面的popup.html中需要js的时候,直接将JS写在动态绑定JS事件会提示: Refused to execute inline script because it violates the following Content Security Policy directive: "script-src 'self' chrome-extension-resource:".. 解决办法: 在popup.html中引用外部的js文件动态绑定JS

  • Javascript动态绑定事件的简单实现代码

    下面是页面的dom结构 复制代码 代码如下: <ul id="test"> <li>One</li> <li>Two</li> <li>Three</li> <li>Four</li> </ul> 下面是javascript代码 复制代码 代码如下: //根据ID获取对象 function id(v) { return document.getElementById(

  • javascript下动态this与动态绑定实例代码

    那么函数就是被掰成两部分储存于对象,一是其函数名(键),一是函数体(值),那么函数中的this一般都指向函数所在的对象.但这是一般而已,在全局调用函数时,我们并没有看到调用者,或者这时就是window.不过,函数声明后,其实并没有绑定到任何对象,因此我们可以用call apply这些方法设置调用者. 一个简单的例子: [script] <script> window.name = "window"; var run = function() { alert("My

  • 深入理解C++的动态绑定与静态绑定的应用详解

    为了支持c++的多态性,才用了动态绑定和静态绑定.理解他们的区别有助于更好的理解多态性,以及在编程的过程中避免犯错误.需要理解四个名词:1.对象的静态类型:对象在声明时采用的类型.是在编译期确定的.2.对象的动态类型:目前所指对象的类型.是在运行期决定的.对象的动态类型可以更改,但是静态类型无法更改.关于对象的静态类型和动态类型,看一个示例: 复制代码 代码如下: class B{}class C : public B{}class D : public B{}D* pD = new D();/

  • C++实现动态绑定代码分享

    C++实现动态绑定代码分享 #include <iostream> #include<string> using namespace std; class BookItem { private: string bookName; size_t cnt; public: BookItem(const string&s,size_t c,double p): bookName(s),cnt(c),price(p) {} ~BookItem(){} protected: doub

  • Java面试题-实现复杂链表的复制代码分享

    阿里终面在线编程题,写出来与大家分享一下 有一个单向链表,每个节点都包含一个random指针,指向本链表中的某个节点或者为空,写一个深度拷贝函数,拷贝整个链表,包括random指针.尽可能考虑可能的异常情况. 算法如下: /* public class RandomListNode { int label; RandomListNode next = null; RandomListNode random = null; RandomListNode(int label) { this.labe

  • Python生成数字图片代码分享

    本文向大家分享了几段Python生成数字图片的代码,喜欢的朋友可以参考.具体如下: 最终版本 # -*- coding:utf-8 -*- from PIL import Image,ImageFont,ImageDraw,ImageFilter import random import os import time class Code(object): def __init__(self, imgSize=(35,35),\ fontSize=25, bgColor=(255,)*4, fo

  • PHP Web木马扫描器代码分享

    不废话了,直接贴代码了. 代码如下: <?php header('content-type:text/html;charset=gbk'); set_time_limit(0);//防止超时 /** * * php目录扫描监控增强版 * * @version 1.0 * 下面几个变量使用前需要手动设置 * **/ /*===================== 程序配置 =====================*/ $pass="test";//设置密码 $jkdir=&quo

  • Java实现JS中的escape和UNescape代码分享

    众所周知,JavaScript中escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串.下面,我们就来看看 Java语言中类似JavaScript中的escape() 和unescape() 转码方法,具体代码如下: public class EscapeUnescape { public static String escape(String src) { int i; char j; StringBuffer tmp = new StringBuffer(); tm

  • JavaScript图片放大技术(放大镜)实现代码分享

    复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv=&qu

  • Angular实现下载安装包的功能代码分享

    废话不多说了,直接给大家贴代码了,具体代码如下所示: <!DOCTYPE html> <html ng-app="myPro"> <head> <meta charset="UTF-8"> <title>angular-实现下载安装包的功能</title> <script src="js/angular.min.js"></script> <sc

  • 手机端转盘抽奖代码分享

    演示效果如下: 不废话了,直接给大家贴代码了. html部分 <div class="turntableWap top10"> <table border="0" cellspacing="0"> <tr> <td tag="0"><img src="../images/4.png" alt="4元"></td> &

  • 为输入框加入数字js校验代码分享

    js限制只能数字输入,并且在把输入的"非法字符"清除掉之后将焦点停留在输入非法字符的位置,参考如下: html部分: <input value="" type="text" onkeyup="javascript:RepNumber(this)"> JavaScript部分: function RepNumber(obj) { var reg = /^[\d]+$/g; if (!reg.test(obj.valu

  • BootStrap轻松实现微信页面开发代码分享

    1.  行长度: <div class="col-md-12"> </div> 2.modal <div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true"> <

随机推荐