//多态性
    //从派生类到基类的转换
    //引用或者指针既可以指向基类对象,也可以指向派生类对象
    //只有通过引用或者指针调用虚函数才会发生动态绑定。
    //为什么定义虚的函数?可以重新定义。只有虚函数才可以重写,(基类或者派生类里面)

////动态绑定的方法,执行出来的效果,就是多态

 #include <iostream>//txwtech-202001
#include <string>//多态,动态绑定 using namespace std;//导入名称空间 class Animal
{
//成员略
}; class Dog :public Animal
{
//成员略
};
class Cat :public Animal
{ };
class Item_base
{
public:
//int x;
Item_base(const std::string &book = "",
double sales_price = 0.0) :isbn(book), price(sales_price) {}//构造函数
std::string book() const
{
return isbn;
}
virtual double net_price(size_t n) const//为什么定义虚的函数?可以重新定义。只有虚函数才可以重写
{
return n * price;
} private://类的内部使用
std::string isbn;
protected://专门用来做继承用的
double price; };
class Bulk_item :public Item_base
{
public:
Bulk_item(const std::string &book = "", double sales_price = 0.0,
size_t qty = , double disc_rate = 0.0) :
Item_base(book, sales_price), min_qty(qty), discount(disc_rate) {}
void test()
{
//cout << x << endl;
cout << price << endl;
//cout << isbn << endl;
}
void test2(const Bulk_item &d, const Item_base &b)
{
//cout << d.x << endl;
cout << d.price << endl;
//cout << b.x << endl;
//cout << b.price << endl;
}
double net_price(size_t cnt) const//继承函数时,这里可以重定义,继承函数
{
if (cnt >= min_qty)
return cnt * ( - discount)*price;
else
return cnt * price; } private:
size_t min_qty;
double discount; };
//做一个函数
void print_total(ostream &os, Item_base *item, size_t n)
{
os << "ISBN: " << item->book() << "\t number sold: " << n << "\ttotal price: " << item->net_price(n) << endl;
//item->net_price(n)代码就是多态的
}
int main()
{
//Animal a;
//Dog d;
//Cat c;
//Item_base item("0-12-3456-789", 9.9);
//cout << item.book() << ": " << item.net_price(10) << endl;
////cout << item.x << endl;
///*cout << item.isbn << endl;
//cout << item.price << endl;*/
////cout << "hello111" << endl;
//Bulk_item item2("0-12-3456-789", 9.9, 10, 0.12);
////cout << item2.x << endl;
//cout << item2.book() << ": " << item2.net_price(10) << endl;
//item2.test();
//item2.test2(item2, item); //多态,动态绑定的实现 Item_base* a = new Item_base("1-234-567-01",11.0);
Bulk_item* b = new Bulk_item("1-234-567-02",22.0,,0.05);//指向子类对象的指针 print_total(cout,a,);
print_total(cout,b,); Item_base* books[];//指针数组,5个指针
books[] = new Item_base("0-123-456-01",10.0);//new 创建基类对象
books[] = new Bulk_item("0-123-456-01", 20.0,,0.05);//new 也可以指向派生类对象
books[] = new Item_base("0-123-456-03", 30.0);//new 创建基类对象
books[] = new Bulk_item("0-123-456-04", 40.0, , 0.15);//new 也可以指向派生类对象
books[] = new Bulk_item("0-123-456-05", 50.0, , 0.18);//new 也可以指向派生类对象 int num[];
num[] = ;
num[] = ;
num[] = ;
num[] = ;
num[] = ; for (int i = ; i < ; i++)
{
print_total(cout,books[i],num[i]);
//动态绑定的方法,执行出来的效果,就是多态
//根据指针所指向的对象不同,指向不同的对象,对象去调用不同的虚函数。有可能是基类,有可能是
//派生类的。
}
//分别调用基类的netprice与派生类的Netprice. netprice就是多态,根据对象决定(基类不打折,派生类打折)
//比如飞机在飞,鸟儿也在非,不同的飞 getchar();
return ; //多态性
//从派生类到基类的转换
//引用或者指针既可以指向基类对象,也可以指向派生类对象
//只有通过引用或者指针调用虚函数才会发生动态绑定。
//为什么定义虚的函数?可以重新定义。只有虚函数才可以重写,(基类或者派生类里面)
}

cc26a_demo-CppPrimer_动态绑定_多态-代码示范的更多相关文章

  1. 自学Python5.6-面向对象三大基本特征_多态

    自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...

  2. 《Java编程思想》学习笔记_多态

    多态 多态指一个行为产生多种状态,针对父类类型可接收其子类类型,最终执行的状态由具体子类确定,其不同子类可呈现出不同状态.例如人[父类]都会跑步[行为],但小孩[子类]跑步.成年人[子类]跑步.运动员 ...

  3. 关于AJAX 的交互模型、交互流程及代码示范

    AJAX  = 异步JavaScript + XML. 它是一种用于创建快速动态网页的技术.通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况 ...

  4. Java 动态绑定和多态

    动态绑定和多态 动态绑定是指:"在执行程序期间(而非编译期间),判断引用所指对象的实际类型,调用其相应的方法." 动态绑定(多态)存在的条件 要有继承. 要有重写. 父类引用指向子 ...

  5. c++ UDP套接字服务器端代码示范

    c++ UDP套接字服务器端代码示范 #include<winsock2.h> //包含头文件 #include<stdio.h> #include<windows.h& ...

  6. cc28c_demo.cpp,派生类的构造函数和析构函数-代码示范3

    cc28c_demo.cpp,派生类的构造函数和析构函数-代码示范3 //派生类的构造函数和析构函数//派生类的构造函数(执行步骤)//--执行基类的构造函数//--执行成员对象的构造函数//--执行 ...

  7. c++ cc24a_demo //转换函数,用来做转换操作符,int()括号里面必须是空的,必须定义为const,代码示范

    c++ cc24a_demo //转换函数,用来做转换操作符,int()括号里面必须是空的,必须定义为const,代码示范 #include <iostream> #include < ...

  8. cc22a_demo_c++重载自增自减操作符-代码示范

    cc22a_demo_c++重载自增自减操作符-代码示范 #define _CRT_SECURE_NO_WARNINGS #include <iostream> using namespa ...

  9. MFC基于CAsyncSocket套接字客户端代码示范

    MFC基于CAsyncSocket套接字客户端代码示范 https://blog.csdn.net/txwtech/article/details/93016190

随机推荐

  1. TCP实现连接传输案例

    使用的类    ServerSocket 服务器端        构造方法:ServerSocket(端口号); 接收端使用    方法:accept(); 返回一个 Socket对象    getI ...

  2. 搭建本地的yum仓库-较简单

    1.创建目录安装软件程序 1.在/root路径下创建123.sh文件,把此文件复制到123.sh里,  sh 123.sh2.首选安装nginx,作为web展示 3.强力清除老版本残留rpm -e n ...

  3. 这次终于可以愉快的进行 appium 自动化测试了

    appium 是进行 app 自动化测试非常成熟的一套框架.但是因为 appium 设计到的安装内容比较多,很多同学入门都跪在了环境安装的部分.本篇讲述 appium 安卓环境的搭建,希望让更多童鞋轻 ...

  4. java1.8时间处理

    object TimeUtil { var DEFAULT_FORMAT = DateTimeFormatter.ofPattern("yyyyMMddHHmmss") var H ...

  5. Java动态代理与静态代理以及它能为我们做什么

    相信我们在网上和平时学习和工作中或多或少都接触过Java的代理模式,经常听到什么静态代理.动态代理的一些名词.但我们是否真的很清楚这些呢?至少我在面试时,发现很多人并不很清楚. 首先代理比较好理解,就 ...

  6. Rocket - regmapper - RegisterCrossing

    https://mp.weixin.qq.com/s/82iLT-fmDg9Comp2p9bxKg 简单介绍RegisterCrossing的实现. 1. BusyRegisterCrossing 简 ...

  7. 从0开始探究vue-组件化-组件之间传值

    理解 Vue中有个非常重要的核心思想,就是组件化,组件化是为了代码复用 什么是组件化 组件化,就像一个电脑主机里的主板,有内存条的插口,有硬盘,光驱等等的插口,我们的项目,就像一个电脑主机,通过各种组 ...

  8. QTI EAS学习之find_energy_efficient_cpu

    Energy Awareness Scheduler是由ARM和Linaro开发的新的linux kernel调度器. 原先CFS调度器是基于policy进行调度,并有不同的吞吐量.例如,有一个新的t ...

  9. Java实现 LeetCode 486 预测赢家

    486. 预测赢家 给定一个表示分数的非负整数数组. 玩家1从数组任意一端拿取一个分数,随后玩家2继续从剩余数组任意一端拿取分数,然后玩家1拿,--.每次一个玩家只能拿取一个分数,分数被拿取之后不再可 ...

  10. Java中map.getOrDefault()方法的使用

    Map.getOrDefault(Object key, V defaultValue)方法的作用是:   当Map集合中有这个key时,就使用这个key值:   如果没有就使用默认值defaultV ...