仅适用于单个功能的部分模板专业化
Partial template specialization only for a single function
我有一个模板,我想将指针类型或实例类型作为模板参数。一个例子:
class FOO {};
class ItemGetter {
virtual FOO * GetItem(int index) = 0;
};
template<class T>
class ArrayContainer : public ItemGetter {
T *array;
ArrayContainer(T * array) {
this->array = array;
}
/*
* A lot of other functions.
* I want to write them only once
* ....
*/
/* If the T Parameter is an instance Type */
FOO * GetItem(int index) {
return &this->array[index];
}
/* If the T Parameter is an pointer Type */
FOO * GetItem(int index) {
return this->array[index];
}
};
void usage() {
FOO fooArray[100];
FOO * fooPointerArray[100];
auto bar1 = ArrayContainer<FOO>(fooArray);
auto bar2 = ArrayContainer<FOO*>(fooPointerArray);
}
我如何专门为指针和实例变体的GetItem()
函数(不写两次其他所有功能)?
延迟到超载的免费功能:
#include <cstddef>
class FOO {};
template<class T>
T* get_t(T* array, std::size_t index)
{
return array + index;
}
template<class T>
T* get_t(T** array, std::size_t index)
{
return array[index];
}
template<class T>
class ArrayContainer {
T *array;
public:
ArrayContainer(T * array)
: array(array)
{
}
/*
* A lot of other functions.
* I want to write them only once
* ....
*/
auto GetItem(std::size_t index)
{
return get_t(array, index);
}
};
void usage() {
FOO fooArray[100];
FOO * fooPointerArray[100];
auto bar1 = ArrayContainer<FOO>(fooArray);
auto bar2 = ArrayContainer<FOO*>(fooPointerArray);
FOO* f = bar1.GetItem(2);
f = bar2.GetItem(5);
}
或,为了更好地封装,从导出Getter函数过载的服务类中私下派生为静态成员。
#include <cstddef>
class FOO {};
struct ArrayContainerServices
{
template<class T>
static
T* ImplementGetItem(T* array, std::size_t index)
{
return array + index;
}
template<class T>
static
T* ImplementGetItem(T** array, std::size_t index)
{
return array[index];
}
};
template<class T>
class ArrayContainer
: private ArrayContainerServices // note - private inheritance
{
T *array;
public:
ArrayContainer(T * array)
: array(array)
{
}
/*
* A lot of other functions.
* I want to write them only once
* ....
*/
auto GetItem(std::size_t index)
{
return ImplementGetItem(array, index);
}
};
void usage() {
FOO fooArray[100];
FOO * fooPointerArray[100];
auto bar1 = ArrayContainer<FOO>(fooArray);
auto bar2 = ArrayContainer<FOO*>(fooPointerArray);
FOO* f = bar1.GetItem(2);
f = bar2.GetItem(5);
}
相关文章:
- FLTK 2.0构建和演示,适用于VS2019的2011年左右的代码库
- C++17 - 使用自定义分配器的节点提取/重新插入 - 适用于 clang++/libc++,但不适用于 libstd
- "string.h"在构建适用于iOS的qt应用程序中找不到消息
- 适用于 WebView2 旧版本的示例应用程序
- 在 NVIDIA GEFORCE GTX 1050 上下载适用于 Windows 10 的 openCL 1.2
- __attribute__(优化(0))) 是否适用于"recursively"?
- 为什么 std::erase(std::erase_if) 不是适用于<algorithm>任何容器的模板?
- 使用一个参数的模板函数时出错(适用于 2)
- 使用 适用于 Android 和 iOS 的 tf-lite C++ API
- 为什么这适用于 G++ 而不是 CLANG?
- 适用于 macOS 的 Xcode 应用程序。这就是我设置从USB麦克风输入获取音频的方式。一年前工作,现在没有了。为什么
- 适用于 Linux 的 c++ 上的代理脚本
- 为什么我的 SFINAE 表达式不再适用于 GCC 8.2?
- 使输出流式处理运算符适用于 boost::variant<std::vector<int>、int、double 的正确方法是什么>
- 有没有适用于Windows.lib文件的GNU二进制文件描述符(BFD)
- 模板函数仅适用于VS
- 如何在cmake中包含适用于g++或viceversa的库
- 适用于win32、linux、mac的POSIX C包装器
- WinDBG适用于从Visual Studio 2015保存的转储,但不适用于任务管理器。显示异常代码"not found"
- 从uint8_t到NPY_UINT16 PyArray_SimpleNewFromData.适用于Linux,但不适用于