15.11 添加了debug()函数
#ifndef QUOTE_H
#define QUOTE_H
#include <iostream>
using namespace std;
class Quote {
public:
Quote() = default;
Quote(const string &book, double sales_price):
bookNo(book), price(sales_price) { }
string isbn() const { return bookNo; };
virtual double net_price(size_t n) const
{ return n * price; }
virtual void debug() { cout << "bookNo: "<< bookNo << " price: " << price << endl; }
virtual ~Quote() = default;
private:
string bookNo;
protected:
double price = 0.0;
};
class Bulk_quote: public Quote {
public:
Bulk_quote() = default;
Bulk_quote(const string &book, double p, size_t qty, double disc):
Quote(book, p), min_qty(qty), discount(disc) { }
void debug() override { Quote::debug(); cout << "min_qty= " << min_qty << " discount= " <<
discount << endl; }
double net_price(size_t) const override;
private:
size_t min_qty = 0;
double discount = 0.0;
};
class Lim_quote: public Quote {
public:
Lim_quote() = default;
Lim_quote(const string &book, double p, size_t qty, double disc):
Quote(book, p), max_qty(qty), discount(disc) { }
void debug() override { Quote::debug(); cout << "max_qty= " << max_qty << " discount= " <<
discount << endl; }
double net_price(size_t) const override;
private:
size_t max_qty = 0;
double discount = 0.0;
};
double print_total(ostream &os, const Quote &item, size_t n);
#endif
15.12 override:如果用override标记了某函数,但并未覆盖已存在的虚函数,将报错;final:函数定义为final,覆盖该函数的操作将引发错误。
15.13 将导致无限递归,修改:
#include <iostream>
using namespace std;
class base {
public:
base(const string &s): basename(s) { }
string name() { return basename; }
virtual void print(ostream &os) { os << basename; }
private:
string basename;
};
class derived: public base {
public:
derived(const string &s, int val): base(s), i(val) { }
void print(ostream &os) override { base::print(os); os << " " << i; }
private:
int i;
};
int main()
{
base b("base");
derived d("derived", 6);
b.print(cout);
cout << endl;
d.print(cout);
cout << endl;
return 0;
}
15.14 基类; 派生类; 基类; 基类; 基类; 派生类
15.15
#ifndef QUOTE_H
#define QUOTE_H
#include <iostream>
using namespace std;
class Quote {
public:
Quote() = default;
Quote(const string &book, double sales_price):
bookNo(book), price(sales_price) { }
string isbn() const { return bookNo; };
virtual double net_price(size_t n) const
{ return n * price; }
virtual void debug() { cout << "bookNo: "<< bookNo << " price: " << price << endl; }
virtual ~Quote() = default;
private:
string bookNo;
protected:
double price = 0.0;
};
class Disc_quote: public Quote {
public:
Disc_quote() = default;
Disc_quote(const string &book, double price, size_t qty, double disc):
Quote(book, price), quantity(qty), discount(disc) { }
double net_price(size_t) const = 0;
protected:
size_t quantity = 0;
double discount = 0.0;
};
class Bulk_quote: public Disc_quote {
public:
Bulk_quote() = default;
Bulk_quote(const string &book, double p, size_t qty, double disc):
Disc_quote(book, p, qty, disc) { }
double net_price(size_t) const override;
private:
size_t min_qty = 0;
double discount = 0.0;
};
class Lim_quote: public Disc_quote {
public:
Lim_quote() = default;
Lim_quote(const string &book, double p, size_t qty, double disc):
Disc_quote(book, p, qty, disc) { }
double net_price(size_t) const override;
private:
size_t max_qty = 0;
double discount = 0.0;
};
double print_total(ostream &os, const Quote &item, size_t n);
#endif
15.16 net_price()函数不需要改变
15.17 无法声明Disc_quote对象。
15.18 d1和dd1能够合法赋值,其他不行。只有当派生类公有的继承基类时,用户才能使用派生类向基类的转换。
15.19 Derived_from_Private不合法;当D继承自B:对于用户代码,只有公有继承,能使用D到B的转换;对于D的成员和友元,任何继承方式都能使用D到B的转换;对于D的派生类的成员和友元,公有和保护继承能使用D到B的转换。
15.20 测试代码如下 ,注释掉的部分时非法的:
#include <iostream>
using namespace std;
class Base
{
public:
void pub_mem();
protected:
int prot_mem;
private:
char priv_mem;
};
struct Pub_Derv: public Base
{
int f() { return prot_mem; }
void memfcn(Base &b)
{
b = *this;
cout << "Pub_Derv" << endl;
}
};
struct Priv_Derv: private Base
{
int f1() const { return prot_mem; }
void memfcn(Base &b)
{
b = *this;
cout << "Priv_Derv" << endl;
}
};
struct Prot_Derv: protected Base
{
int f2() { return prot_mem; }
void memfcn(Base &b)
{
b = *this;
cout << "Prot_Derv" << endl;
}
};
struct Derived_from_Public: public Pub_Derv
{
int use_base() { return prot_mem; }
void memfcn(Base &b)
{
b = *this;
cout << "Derived_from_Public" << endl;
}
};
/*
struct Derived_from_Private: public Priv_Derv
{
int use_base() { return prot_mem; }
void memfcn(Base &b)
{
b = *this;
cout << "Derived_from_Private" << endl;
}
};
*/
struct Derived_from_Protected: protected Prot_Derv
{
int use_base() { return prot_mem; }
void memfcn(Base &b)
{
b = *this;
cout << "Derived_from_Protected" << endl;
}
};
int main()
{
Pub_Derv d1;
Priv_Derv d2;
Prot_Derv d3;
Derived_from_Public dd1;
// Derived_from_Private dd2;
Derived_from_Protected dd3;
//用户代码
Base base;
Base *p = &d1;
// p = &d2;
// p = &d3;
p = &dd1;
// p = &dd2;
// p = &dd3;
//成员调用
d1.memfcn(base);
d2.memfcn(base);
d3.memfcn(base);
//派生类的成员调用
dd1.memfcn(base);
// dd2.memfcn(base);
dd3.memfcn(base);
return 0;
}
15.21 (b)的继承体系:公共基类Figure,派生类Figure_2D和Figure_3D继承自Figure,方格和圆继承自Figure_2D,球和圆锥继承自Figure_3D。
15.22
#ifndef FIGURE_H
#define FIGURE_H
class Figure {
public:
Figure(double, double);
private:
double x, y;
};
class Figure_2D: public Figure {
public:
Figure_2D(double, double);
virtual double area() = 0;
virtual double perimeter() = 0;
};
class Figure_3D: public Figure {
public:
Figure_3D(double, double, double);
virtual double cubage() = 0;
protected:
double zSize;
};
class Retangle: public Figure_2D {
public:
Retangle(double, double);
double area() override;
double perimeter() override;
};
class Circle: public Figure_2D {
public:
Circle(double, double);
double area() override;
double perimeter() override;
};
class Sphere: public Figure_3D {
public:
Sphere(double, double, double);
double cubage() override;
};
class Cone: public Figure_3D {
public:
Cone(double, double, double);
double cubage() override;
};
#endif