首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否可以不实例化template类而显式实例化template类的template成员?

是否可以不实例化template类而显式实例化template类的template成员?
EN

Stack Overflow用户
提问于 2014-12-13 19:37:10
回答 1查看 83关注 0票数 0

我想显式实例化template成员,但不实例化template类。但是我得到了编译器错误,所以这是可能的吗?下面是我的代码:

代码语言:javascript
复制
//mytemplate.h
template <class T>
class mytemplate
{
 public:
  mytemplate(T* tt)
  {
     mT = tt;
  }
  template<class B>
  void print(const B& bb); 
  T* mT;
};
代码语言:javascript
复制
//in mytemplate.cpp
#include "mytemplate.h"
template<typename T>
template<typename B>
void mytemplate<T>:: print(const B& bb)
{
   B b = bb;
}

template<typename T> void  mytemplate<T>::print<float>(const float&) const;
template<typename T> void    mytemplate<T>::print<int>(const int&) const;
代码语言:javascript
复制
// main.cpp
int main()
{
  int d =0;
  mytemplate<int> k(&d);
  k.print<float>(4.0);
}
EN

回答 1

Stack Overflow用户

发布于 2014-12-13 20:23:11

对于模板,它总是有助于将问题分解为尽可能小的构建块。可以根据对模板自由函数的调用来编写mytemplate::print。

这样,您就可以实现成员函数的部分专门化效果。

这里的一个主要问题是“print()方法应该做什么?”以下是mytemplate<T>向自由函数提供打印策略的示例。当然,没有理由策略不能是通过其他(可能是专用的)模板自由函数构造的其他类。

代码语言:javascript
复制
// Policy is a concept which supports 2 methods:
// print_prefix() and print_postfix()
//
template<class Policy, class B>
void print_with_policy(const Policy& policy, const B& value) const
{
  policy.print_prefix();
  cout << value;
  policy.print_postifx();
}

template<class T>
struct mytemplate
{
  // implement in terms of a free function
  template<class B> void print(const B& value) {
    print_with_policy(*this, value);
  }

  // policy concept implementation
  void print_prefix() const {
    cout << "prefix-";
  }

  void print_postfix() const {
    cout << "-postfix";
  }
};

扩展该示例以使用具有字符串专门化的单独策略类:

代码语言:javascript
复制
template<typename B>
struct default_policy {
    default_policy(const B& value) : _value(value) {}
    void operator()() const {
        cout << "(" << _value << ")";
    }
private:
    const B& _value;
};

template<typename B>
struct quoted_policy {
    quoted_policy(const B& value) : _value(value) {}
    void operator()() const {
        cout << '"' << _value << '"';
    }
private:
    const B& _value;
};

template<class B>
default_policy<B> make_policy(const B& value) {
    return default_policy<B>(value);
}

// overload for B being a string
quoted_policy<std::string> make_policy(const std::string& value) {
    return quoted_policy<std::string>(value);
}

template<class T>
struct mytemplate
{
    // implement in terms of a free function
    template<class B> void print(const B& value) {
        make_policy(value)();
        cout << endl;
    }

};

int main()
{
    struct foo{};
    mytemplate<foo> fooplate;
    fooplate.print(int(8));
    fooplate.print(std::string { "a string" });
    fooplate.print("not a string");


    return 0;
}

输出:

代码语言:javascript
复制
(8)
"a string"
(not a string)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27458341

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档