作者热门文章
- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试专门化一个类方法 foo()
。这适用于完整的模板特化。但是,这不适用于部分模板特化。
这里是在 GCC 和 Clang 上编译良好的示例代码:
#include <iostream>
#include <string>
template <typename Key, typename Value>
struct SimpleKey {
Key key;
Value value;
void foo() const {
std::cout << "base" << std::endl;
}
};
/*
// Uncomment this and it won't work !
template<typename Key>
void SimpleKey<Key, std::string>::foo() const {
std::cout << "partial" << std::endl;
}
*/
template<>
void SimpleKey<int, std::string>::foo() const {
std::cout << "full" << std::endl;
}
int main() {
SimpleKey<double, std::string> key1{1.0,"key1"};
key1.foo();
SimpleKey<int, std::string> key2{1,"key2"};
key2.foo();
}
我在取消注释相关代码时得到的关于 Clang 和 GCC 的错误是:
error: invalid use of incomplete type ‘struct SimpleKey >’ void SimpleKey::foo() const {
我应该怎么做才能使部分模板特化以“最小”努力正常工作?
最佳答案
您可以显式特化类模板的特定隐式实例化的成员函数。但这对于部分特化是不允许的。如果你不想写一个完整的偏特化,你可以考虑使用标签分派(dispatch):
private:
void foo(std::true_type /*value_is_string*/) const { /* "partial" */ }
void foo(std::false_type /*value_is_string*/) const { /* "base" */ }
public:
void foo() const { return foo(std::is_same<Value, std::string>()); }
或将 foo()
重构为您部分专门化的基类模板。
关于c++ - 部分模板特化 c++ 的不完整类型无效使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30816813/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 4 年前。
正如您在 this travis.yml 中看到的那样文件,我的代码依赖于一些第三方库,我在构建项目之前将它们安装在远程系统上。 Travis 每次推送提交时都会下载并构建这些库,这可以避免吗?我的意
我是一名优秀的程序员,十分优秀!