繼承(inheritance)和動態綁定(dynamic binding) 是面向對象的重要組成部分, 即繼承(inheritance)和多態(polymorphism),
可以使 派生類(derived class)擁有 基類(base class) 的接口(interface);
派生類可以覆寫(override)基類的虛函數(virtual function), 符合特定的功能;
派生類可以隱式地轉換為基類 (derived-to-base conversion), 但不可逆, 因為派生類的對象包含自己的部分 和 基類的對象的部分;
盡量使用基類的構造器, 去構造基類的對象, 可以易於管理; 對於靜態成員,只定義(define)一次, 忽略其他定義;
可以顯示定義類無法被繼承, 在類後添加 "final" 限定詞;
代碼:
/* * CppPrimer.cpp * * Created on: 2013.11.12 * Author: Caroline */ /*eclipse cdt*/ #include <iostream> #include <string> #include <cstddef> using namespace std; class Quote { public: Quote() = default; Quote (const std::string& book, double sales_price) : bookNo (book), price (sales_price) {} std::string isbn() const { return bookNo; } virtual double net_price (std::size_t n) const { return n* price; } //虛函數 virtual ~Quote() = default; //動態綁定析構器 private: std::string bookNo; protected: //受保護類型 double price = 0.0; }; class Bulk_quote final : public Quote { //final限定詞, 無法被繼承 public: Bulk_quote() = default; Bulk_quote(const std::string&book, double p, std::size_t qty, double disc) : Quote(book, p), min_qty(qty), discount(disc) {} //使用基類的構造器 double net_price(std::size_t cnt) const override; private: std::size_t min_qty = 0; //折扣的最小量 double discount = 0.0; //折扣 }; double Bulk_quote::net_price(std::size_t cnt) const { if (cnt >= min_qty) return cnt * (1-discount) * price; else return cnt * price; } int main (void) { Quote q("CppPrimer", 99); Bulk_quote bq("CppPrimer", 99, 10, 0.5); std::size_t n = 20; std::cout << "We want to buy " << n << " books. " << std::endl; std::cout << "Quote net_price : " << q.net_price(n) << std::endl; std::cout << "Bulk_quote net_price : " << bq.net_price(n) << std::endl; return 0; }
作者:csdn博客 Spike_King