适配器模式(大话设计模式)C/C++版本

ops/2024/10/18 6:11:27/

适配器模式

在这里插入图片描述

C++

#include <iostream>
using namespace std;
// 球员
class Player
{
protected:string name;public:Player(string name) : name(name) {}virtual void Attack() = 0;virtual void Defense() = 0;virtual ~Player() {}
};
// 前锋
class Forwards : public Player
{
public:Forwards(string name) : Player(name) {}virtual void Attack(){cout << "前锋 " << name << "进攻" << endl;}virtual void Defense(){cout << "前锋 " << name << "防守" << endl;}
};// 中锋
class Center : public Player
{
public:Center(string name) : Player(name) {}virtual void Attack(){cout << "中锋 " << name << "进攻" << endl;}virtual void Defense(){cout << "中锋 " << name << "防守" << endl;}
};// 后卫
class Guards : public Player
{
public:Guards(string name) : Player(name) {}virtual void Attack(){cout << "后卫 " << name << "进攻" << endl;}virtual void Defense(){cout << "后卫 " << name << "防守" << endl;}
};class ForeignCenter
{
public:void SetName(string name){this->name = name;}string GstName(){return name;}void ForeignAttack(){cout << "外籍中锋 " << name << " 进攻" << endl;}void ForeignDefense(){cout << "外籍中锋 " << name << " 防守" << endl;}private:string name;
};// 适配器类 翻译者
class Translator : public Player
{
public:Translator(string name) : Player(name){ym = new ForeignCenter;ym->SetName(name);}~Translator(){if (ym != NULL)delete ym;}void Attack(){ // 翻译者将Attack 翻译成 ForeignAttackym->ForeignAttack();}void Defense(){ym->ForeignDefense(); // 翻译者将Defense 翻译成 ForeignDefense}private:ForeignCenter *ym; // 外籍中锋
};
int main()
{Player *b = new Forwards("巴蒂尔");b->Attack();Player *c = new Guards("麦克格雷迪");c->Attack();Player *ym = new Translator("姚明"); // 姚明问: "Attack和Defense是什么意思?"ym->Attack();ym->Defense();return 0;
}

C

#include <stdio.h>
#include <stdlib.h>
#include <string.h>typedef struct Player
{char name[50];void (*attack)(const char *);void (*defense)(const char *);
} Player;typedef struct Forwards
{Player base;
} Forwards;typedef struct Center
{Player base;
} Center;typedef struct Guards
{Player base;
} Guards;typedef struct ForeignCenter
{char name[50];
} ForeignCenter;typedef struct Translator
{Player base;ForeignCenter *foreignCenter;
} Translator;void forwards_attack(const char *name)
{printf("前锋 %s 进攻\n", name);
}void forwards_defense(const char *name)
{printf("前锋 %s 防守\n", name);
}void center_attack(const char *name)
{printf("中锋 %s 进攻\n", name);
}void center_defense(const char *name)
{printf("中锋 %s 防守\n", name);
}void guards_attack(const char *name)
{printf("后卫 %s 进攻\n", name);
}void guards_defense(const char *name)
{printf("后卫 %s 防守\n", name);
}void foreign_center_attack(ForeignCenter *fc)
{printf("外籍中锋 %s 进攻\n", fc->name);
}void foreign_center_defense(ForeignCenter *fc)
{printf("外籍中锋 %s 防守\n", fc->name);
}Player *create_forwards(const char *name)
{Player *p = (Player *)malloc(sizeof(Player));strcpy(p->name, name);p->attack = forwards_attack;p->defense = forwards_defense;return p;
}Player *create_center(const char *name)
{Player *p = (Player *)malloc(sizeof(Player));strcpy(p->name, name);p->attack = center_attack;p->defense = center_defense;return p;
}Player *create_guards(const char *name)
{Player *p = (Player *)malloc(sizeof(Player));strcpy(p->name, name);p->attack = guards_attack;p->defense = guards_defense;return p;
}Translator *create_translator(const char *name)
{Translator *t = (Translator *)malloc(sizeof(Translator));strcpy(t->base.name, name);t->foreignCenter = (ForeignCenter *)malloc(sizeof(ForeignCenter));strcpy(t->foreignCenter->name, name);t->base.attack = (void (*)(const char *))foreign_center_attack;t->base.defense = (void (*)(const char *))foreign_center_defense;return t;
}void player_free(Player *p)
{free(p);
}void translator_free(Translator *t)
{if (t->foreignCenter)free(t->foreignCenter);free(t);
}int main()
{Player *b = create_forwards("巴蒂尔");b->attack(b->name);Player *c = create_guards("麦克格雷迪");c->attack(c->name);Translator *ym = create_translator("姚明");ym->base.attack(ym->base.name);ym->base.defense(ym->base.name);player_free(b);player_free(c);translator_free(ym);return 0;
}

http://www.ppmy.cn/ops/52315.html

相关文章

《A DECODER-ONLY FOUNDATION MODEL FOR TIME-SERIES FORECASTING》阅读总结

介绍了一个名为TimeFM的新型时间序列预测基础模型&#xff0c;该模型受启发于自然语言处理领域的大语言模型&#xff0c;通过再大规模真实世界和合成时间序列数据集上的预训练&#xff0c;能够在多种不同的公共数据集上实现接近最先进监督模型的零样本预测性能。 该模型使用真…

数据结构:二叉树详解 c++信息学奥赛基础知识讲解

目录 一、二叉树的定义 二、二叉树的形态 三、二叉树的性质 四、二叉树的存储 五、二叉树的创建与遍历&#xff08;递归&#xff09; 六、二叉树实现 创建二叉树 展示二叉树 1、计算数的高度 2、计算数的叶子数量 3、计算数的宽度 4、层次遍历 5、前序遍历 递归写…

linux常用API接口

linux常用API接口 文章目录 linux常用API接口1.应用层内存映射mmap取消内存映射munmap终端打印可用方式1.puts 函数2.文件操作函数 fprintf3.字符输出函数 putchar4.fwrite 函数 2.内核层 1.应用层 内存映射mmap mmap 是一个用于内存映射的系统调用&#xff0c;它可以将一个文…

C语言 -- 宏的变长参数定义

C语言宏定义中的可变参数处理 在C语言的宏定义中&#xff0c;我们可以使用可变参数来创建更加灵活和通用的宏。C99标准引入了__VA_ARGS__&#xff0c;而GNU编译器扩展了...args。这两者在处理可变参数时有所不同。本文将介绍它们的区别、使用场景以及相关示例。 背景介绍 __…

java实现持续集成

要使用Java实现Jenkins持续集成&#xff0c;你可以使用Jenkins的Java客户端库来执行一些常见的操作&#xff0c;例如创建任务&#xff0c;触发构建等。下面是一个简单的示例代码&#xff0c;展示了如何使用Java实现Jenkins持续集成&#xff1a; java import com.offbytwo.jenk…

C# 中不同类型的构造函数

介绍 在本文中&#xff0c;我们将学习 C# 中的构造函数和构造函数类型。C# 中有五种不同类型的构造函数。构造函数用于创建类的对象。以下是 C# 中的构造函数列表。 默认构造函数参数化构造函数复制构造函数静态构造函数私有构造函数 什么是构造函数&#xff1f; 构造函数是…

(转)请介绍一下Redis的数据淘汰策略

1. **NoEviction&#xff08;不淘汰&#xff09;**&#xff1a;当内存不足时&#xff0c;直接返回错误&#xff0c;不淘汰任何数据。该策略适用于禁止数据淘汰的场景&#xff0c;但需要保证内存足够。 2. **AllKeysLFU&#xff08;最少使用次数淘汰&#xff09;**&#xff1a;…

如何关闭软件开机自启,提升电脑开机速度?

如何关闭软件开机自启&#xff0c;提升电脑开机速度&#xff1f;大家知道&#xff0c;很多软件在安装时默认都会设置为开机自动启动。但是&#xff0c;有很多软件在我们开机之后并不是马上需要用到的&#xff0c;开机启动的软件过多会导致电脑开机变慢。那么&#xff0c;如何关…