如何处理模棱两可的模板参数
How to deal with ambiguous template arguments?
我想这更多是一个设计问题。如果这不是正确的地方,请原谅我。假设我有一个代表系统的总RAM
的课程,分为银行:
template <uint16_t bank_sz>
class Ram
{
constexpr static auto BANK_SIZE = bank_sz;
using Bank = std::array<uint8_t, BANK_SIZE>;
public:
uint8_t read(uint8_t bank, uint16_t adr) const;
void write(uint8_t b, uint8_t bank, uint16_t adr);
void dump(std::ostream &os) const;
private:
std::vector<Bank> data_ {};
};
模板在那里,因此用户可以指定银行的大小,因为所讨论的系统可以具有不同尺寸的RAM银行。但是,我觉得这可能会使用户感到困惑,并违反了最少惊喜的原则,因为人们期望模板参数指定总RAM的大小,而不是RAM银行的大小:
Ram<0x2000> work_ram; // 4 KB total of work RAM? (no, 4 KB per bank)
直到运行时,总RAM才知道,只有银行的规模才知道。解决方案是什么?
您可以使Bank
Typedef成为独立模板,然后让Ram
模板以Bank
为其模板参数。即:
template <uint16_t SIZE>
using RamBank = std::array<uint8_t, SIZE>;
template <typename Bank>
class Ram
{
public:
//...
private:
std::vector<Bank> data_;
};
然后将其用作
Ram<RamBank<0x2000>> work_ram;
这对我来说很清楚work_ram
是2KB银行的集合。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 如何处理模棱两可的模板参数
- variadic形式对单个参数的非variadic形式是模棱两可的
- 重载函数的调用 - 以继承的类作为参数 - 是模棱两可的
- C++ 多态函数以 void * 和其他指针类型为参数:是否被认为是模棱两可的
- 为什么即使给出了模板参数,ptr_fun也会发现这是模棱两可的?