策略模式:定义了算法族,分别封装起来.让他们之间可以互相替换.此模式让算法的变化独立于使用算法的客户。
//main-test
// Duck.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include "Duck.h"
int main()
{
CMallardDuck duck;
duck.Display();
duck.Fly();
duck.Quack();
duck.Swim();
return 0;
}
//fly interface
#pragma once
class IFly
{
public:
IFly(void);
virtual ~IFly(void);
public:
virtual void Fly() = 0;
};
//CFlyWithWings
class CFlyWithWings:public IFly
{
public:
CFlyWithWings();
~CFlyWithWings();
public:
virtual void Fly();
};
//CFlyNoWay
class CFlyNoWay:public IFly
{
public:
CFlyNoWay();
~CFlyNoWay();
public:
virtual void Fly();
};
#include "stdafx.h"
#include "Fly.h"
IFly::IFly(void)
{
}
IFly::~IFly(void)
{
}
//CFlyWithWings
CFlyWithWings::CFlyWithWings(void)
{
}
CFlyWithWings::~CFlyWithWings(void)
{
}
void CFlyWithWings::Fly()
{
cout << "I'm flying" << endl;
}
//CFlyNoWay
CFlyNoWay::CFlyNoWay(void)
{
}
CFlyNoWay::~CFlyNoWay(void)
{
}
void CFlyNoWay::Fly()
{
cout << "I can't flying" << endl;
}
//quake interface
#pragma once
//IQuack
class IQuack
{
public:
IQuack(void);
virtual ~IQuack(void);
public:
virtual void Quack() = 0;
};
//CQuack
class CQuack:public IQuack
{
public:
CQuack();
~CQuack();
public:
virtual void Quack();
};
//CMuteQuack
class CMuteQuack:public IQuack
{
public:
CMuteQuack();
~CMuteQuack();
public:
virtual void Quack();
};
//CSqueak
class CSqueak:public IQuack
{
public:
CSqueak();
~CSqueak();
public:
virtual void Quack();
};
#include "stdafx.h"
#include "Quack.h"
IQuack::IQuack(void)
{
}
IQuack::~IQuack(void)
{
}
//CQuack
CQuack::CQuack(void)
{
}
CQuack::~CQuack(void)
{
}
void CQuack::Quack()
{
cout << "Quack" << endl;
}
//CMuteQuack
CMuteQuack::CMuteQuack(void)
{
}
CMuteQuack::~CMuteQuack(void)
{
}
void CMuteQuack::Quack()
{
cout << "<< Slience >>" << endl;
}
//CSqueak
CSqueak::CSqueak(void)
{
}
CSqueak::~CSqueak(void)
{
}
void CSqueak::Quack()
{
cout << "Squeak" << endl;
}
//duck
#pragma once
#include "Fly.h"
#include "Quack.h"
class IDuck
{
public:
IDuck();
virtual ~IDuck(void);
public:
virtual void Display() = 0;
public:
void Fly();
void Quack();
void Swim();
void SetBehavior(IFly* pFly, IQuack* pQuack);
protected:
IFly* m_pFly;
IQuack* m_pQuack;
};
//CMallardDuck
class CMallardDuck:public IDuck
{
public:
CMallardDuck();
~CMallardDuck();
public:
virtual void Display();
};
#include "stdafx.h"
#include "duck.h"
IDuck::IDuck()
{
m_pFly = NULL;
m_pQuack = NULL;
}
IDuck::~IDuck(void)
{
}
void IDuck::SetBehavior(IFly* pFly, IQuack* pQuack)
{
m_pFly = pFly;
m_pQuack = pQuack;
}
void IDuck::Fly()
{
if (NULL == m_pFly)
{
cout << "no fly implement..." << endl;
}
m_pFly->Fly();
}
void IDuck::Quack()
{
if (NULL == m_pQuack)
{
cout << "no quack implement..." << endl;
}
m_pQuack->Quack();
}
void IDuck::Swim()
{
cout << "All duck can swim, even decoys!" << endl;
}
//CMallardDuck
CMallardDuck::CMallardDuck()
{
IFly* pFly = new CFlyWithWings;
IQuack* pQuack = new CSqueak;
SetBehavior(pFly, pQuack);
}
CMallardDuck::~CMallardDuck()
{
if (NULL != m_pFly)
{
delete m_pFly;
m_pFly = NULL;
}
if (NULL != m_pQuack)
{
delete m_pQuack;
m_pQuack = NULL;
}
}
void CMallardDuck::Display()
{
cout << "I am Mallard Duck!" << endl;
}
分享到:
相关推荐
策略模式是一种设计模式,它允许在运行时动态地选择算法或策略,从而使程序能够根据不同的条件执行不同的行为。这种模式的核心思想是将算法封装在独立的类中,这些类具有相同的接口,使得它们可以互相替换而不会影响...
什么是策略模式? 引用一段百度百科的解释: 策略模式是指有一定行动内容的相对稳定的策略名称。策略模式在古代中又称“计策”,简称“计”,如《汉书·高帝纪上》:“汉王从其计”。这里的“计”指的就是计谋、...
策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在Java中,策略模式通常涉及接口或抽象类的实现,允许程序在运行时选择并应用不同的算法或策略。这种模式的核心在于将算法封装到独立的可互换的策略中...
策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在策略模式中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为模式。 策略模式定义了一系列的算法,并将每一个算法封装起来,使...
策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在C#中,策略模式的应用可以帮助我们处理复杂的问题,通过将算法封装在独立的类中,使得我们可以根据需要灵活地选择不同的策略来实现特定的功能。下面...
Java设计模式中的策略模式是一种行为设计模式,它允许在运行时选择算法或策略,从而提供了更大的灵活性。策略模式的核心在于将算法封装到独立的可互换的策略类中,使得算法的变化不会影响到使用算法的客户端代码。 ...
策略模式是一种设计模式,主要目的是将算法的实现与使用算法的环境解耦,使得算法可以在不修改客户端代码的情况下进行变化。这种模式的核心在于定义一系列的算法,并将每一个算法封装起来,使它们可以相互替换,同时...
策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在C++中,策略模式通常通过定义一系列算法类并让它们之间可以互换来实现。这些算法类都实现了一个公共接口,使得它们可以被相同的客户端代码调用,而...
技术: 1. spring事件驱动(ApplicationEventPublisher) 2. 策略模式处理事件 目的: 1. 通过event,代码逻辑异步处理 2. 通过策略模式,构建具体监听实现 3. 解耦 4. 容错(降低代码块错误风险)
接下来我们再说下什么叫策略模式:将每一个算法封装到具有共同接口的独立的类中,从而使得它们可以相互替换。策略模式使得算法可以在不影响到客户端的情况下发生变化。 可能说了这么多你还没明白什么事策略...
策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在这个例子中,我们通过创建不同的图片保存策略(GIFSaver、JPEGSaver、PNGSaver)来实现这一模式,每个策略都实现了同一个接口`ImageSaver`,其中...
策略模式是一种行为型设计模式,它定义了算法族,分别封装起来,让它们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。在PHP中实现策略模式涉及到几个核心概念:抽象策略角色、具体策略角色和环境角色...
### 浅析.NET策略模式 #### 一、策略模式简介 策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。此模式允许在运行时动态地选择算法或策略,从而实现对不同策略的选择与封装。在.NET环境中,策略模式...
在Java中,策略模式主要用来处理同一操作的不同实现,使得系统可以根据不同的条件选择不同的算法或行为。 策略模式的核心结构包括策略接口(Strategy Interface)、具体策略实现(Concrete Strategy ...
SpringBoot结合策略模式实战套路 策略模式是一种常用的设计模式,它可以使我们的代码更加灵活、可维护和可扩展。在SpringBoot项目中,策略模式可以与依赖注入机制相结合,实现更加灵活的业务逻辑处理。在本文中,...
策略模式是一种设计模式,它使你能在运行时改变对象的行为,通过将算法封装在独立的策略类中,使得相同的算法可以有不同的实现。这种模式的主要目的是将决策逻辑与核心业务逻辑解耦,使得算法的选择和使用更加灵活。...