繁体   English   中英

C ++使用来自不同模板类的枚举作为函数参数

[英]C++ use enum from different template class as function parameter

我有两个模板类CarOwnerTruck

// CarOwner.h
#include "Truck.h"
template<size_t T1, typename T2>
class CarOwner {
public:
    enum MyEnum {
        red = 0,
        green
    }

   void DoSomething();

private:
   Truck<DataContainer<T1,T2>> truck_;   
   MyEnum color;
}

// CarOwner.hpp
template<size_t T1, typename T2>
void CarOwner<T1,T2>::DoSomething(){
    this->truck_.setEnum(this->color);
}

// Truck.h
template<typename G>
class Truck {
    void setEnum(CarOwner<T1,T2>::MyEnum color); // <---
}

我的问题是了解如何编写void setEnum();的函数声明void setEnum(); 如上面的代码所示,我实际上想向函数传递CarOwner<T1,T2>::MyEnum color类型的枚举。 因为我需要#include "Truck.h"CarOwner ,我可以不包括CarOwnerTruck类。 此外,模板参数T1T2Truck类中是未知的,因为它具有不同的模板类型G

我不知道如何正确地声明此函数以接受CarOwner<T1,T2>::MyEnum 任何帮助表示赞赏!

编辑:模板参数GT1T2的组合。

这段代码仅是说明我的问题的示例,设计显然很奇怪。

假设Truck实例化为Truck<DataContainer<T1,T2>> ,则可以编写部分专门化的代码:

template<typename G>
class Truck {
    // whatever
};

template<typename T1,typename T2>
class CarOwner;

template<typename T1, typename T2>
class Truck<DataContainer<T1,T2>> {
    void setEnum( typename CarOwner<T1,T2>::MyEnum color );
};

或者,您可以在OwnerType上对setEnum进行模板化:

template<typename G>
class Truck {
  template<typename OwnerType>
  void setEnum( typename OwnerType::MyEnum color);
};

// ...

void CarOwner<T1,T2>::DoSomething(){
  this->truck_.template setEnum<CarOwner<T1,T2>>(this->color);
}

要么 ...

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM