C++設(shè)計模式迪米特法則實例
更新時間:2018年12月24日 14:11:33 作者:wwxy261
這篇文章主要為大家詳細介紹了C++設(shè)計模式迪米特法則實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
迪米特法則(Law of Demeter)又叫作最少知識原則(Least Knowledge Principle 簡寫LKP),就是說一個對象應(yīng)當(dāng)對其他對象有盡可能少的了解,不和陌生人說話。英文簡寫為: LoD.
類的設(shè)計接口盡量封裝完善,讓外部直接調(diào)用
#include<iostream>
#include<string>
#include<vector>
using namespace std;
class AbstractBuilding
{
public:
virtual void sale() = 0;
virtual string getQuality() = 0;
};
class BuildingA :public AbstractBuilding
{
public:
BuildingA()
{
mQulity = "高品質(zhì)";
}
virtual void sale()
{
cout << "樓盤A" << mQulity << "被售賣!" << endl;
}
virtual string getQuality()
{
return mQulity;
}
public:
string mQulity;
};
class BuildingB :public AbstractBuilding
{
public:
BuildingB()
{
mQulity = "低品質(zhì)";
}
virtual void sale()
{
cout << "樓盤B" << mQulity << "被售賣!" << endl;
}
virtual string getQuality()
{
return mQulity;
}
public:
string mQulity;
};
// 中介類
class Mediator
{
public:
Mediator()
{
AbstractBuilding* building = new BuildingA;
vBuilding.push_back(building);
building = new BuildingB;
vBuilding.push_back(building);
}
// 對外提供接口
AbstractBuilding* findMyBuilding(string quality)
{
for (vector<AbstractBuilding*>::iterator it = vBuilding.begin();
it != vBuilding.end(); it++)
{
if ((*it)->getQuality() == quality)
{
return *it;
}
}
return NULL;
}
~Mediator()
{
for (vector<AbstractBuilding*>::iterator it = vBuilding.begin();
it != vBuilding.end(); it++)
{
if (*it != NULL)
delete *it;
}
}
public:
vector<AbstractBuilding*> vBuilding;
};
void test01()
{
Mediator* mediator = new Mediator;
AbstractBuilding* building = mediator->findMyBuilding("低品質(zhì)");
if (building != NULL)
{
building->sale();
}
else
{
cout << "沒有符號條件的樓盤" << endl;
}
}
int main()
{
test01();
system("pause");
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Qt利用QNetwork實現(xiàn)上傳數(shù)據(jù)的示例代碼
這篇文章主要為大家詳細介紹了Qt如何利用QNetwork實現(xiàn)上傳數(shù)據(jù)的 功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-02-02
C語言 數(shù)據(jù)結(jié)構(gòu)中棧的實現(xiàn)代碼
這篇文章主要介紹了C語言 數(shù)據(jù)結(jié)構(gòu)中棧的實現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2016-10-10
C++?qsort函數(shù)排序與冒泡模擬實現(xiàn)流程詳解
qsort是一個庫函數(shù),基于快速排序算法實現(xiàn)的一個排序的函數(shù),下面這篇文章主要給大家介紹了關(guān)于C語言qsort()函數(shù)使用的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-10-10

