【问题标题】:Is there a way to define a template member in a non-template class? #2有没有办法在非模板类中定义模板成员? #2
【发布时间】:2019-11-16 19:20:47
【问题描述】:

我有一个模板类class_A:

// class_A.h
#pragma once

#include <iostream>
#include <tuple>

template <class T>
class class_A
{
public:
    class_A(){}

    T Function_A(T parameter)
    {
        return parameter;
    }
};

我试图在非模板类中使用 class_B 作为私有成员:

// class_B.h
#pragma once

#include <tuple>
#include <iostream>

#include "class_A.h"

class class_B
{
public:
    class_B();

    template <typename T> T Evaluate(T parameter);

private:
    std::tuple<class_A<double>, class_A<char> > As;
};

// class_B.cc
#include "class_B.h"

class_B::class_B(){}

template <typename T>
T class_B::Evaluate(T parameter)
{
    return std::get<class_A<T>>(As).Function_A(parameter); //This is causing error
    //return parameter // This works
}

template double class_B::Evaluate(double parameter);
template char class_B::Evaluate(char parameter);

而我的main.cc 是:

// main.cc
#include<iostream>
#include <string>
#include "class_B.h"

using namespace std;


int main()
{
    class_B B;

    std::cout<< B.Evaluate(5.2) <<std::endl;
    std::cout << B.Evaluate('h') << std::endl;

    return 0;
}

我收到以下错误:

src/class_B.cc:8:12: error: no matching function for call to 'get'
    return std::get<class_A<T>>(As).Evaluate(parameter);
.
.
.
etc.

这是对答案的试用:https://stackoverflow.com/a/55357742/9203360 没有用,但如果能用,那就太理想了。

【问题讨论】:

  • 模板只有标题,没有cc文件!
  • @OblivionreinstateOurMonica,是的 class_A 是模板类,因此它只是标题,而不是 class_B
  • @MichaelKenzel 模板针对相关类型显式实例化,参见例如template double class_B::Evaluate(double parameter);.
  • 您是否针对 C++14 或更高版本进行编译? (您使用std::get时需要)
  • 确实,这是问题的一部分,谢谢

标签: c++ class templates


【解决方案1】:

正如我在 cmets 中提到的,std::get 的重载将类型作为模板参数并返回该类型的元组元素仅在 C++14 之后才可用。

根据您的评论,您没有针对 C++14 或更高版本进行编译,因此与类型为第一个模板参数的 std::get 不匹配。

【讨论】:

    【解决方案2】:

    std::get>(As)

    获取class_A的实例,所以不能调用Evaluate Method,不存在。你应该调用方法Function_A,或者在class_A中定义Evaluate方法

    return std::get<class_A<T>>(As).Function_A(parameter); // Call Function_A
    

    它适用于 Visual Studio 2015 - Windows 平台 10.0.17763.0

    另外,std::get 需要 c++14 才能工作。

    【讨论】:

    • 这是真的,但不是错误消息所抱怨的。我假设 OP 的意思是命名 Function_A 而不是 Evaluate
    • 你是对的,这是一个愚蠢的错误......实际上@uneven_mark 的答案是我错过的东西
    猜你喜欢
    • 2019-08-16
    • 1970-01-01
    • 1970-01-01
    • 2020-03-28
    • 2017-10-20
    • 2012-11-03
    • 1970-01-01
    • 1970-01-01
    • 2021-07-26
    相关资源
    最近更新 更多