在C ++中调用模板参数的静态函数

时间:2016-08-23 13:12:54

标签: java c++ templates generics static

以下Java代码在泛型参数printText(text)上调用静态方法T,该参数表示Printer的派生类。是否有可能在C ++中实现完全相同的行为?如果是,怎么样?

public class Printer {

   public static void printText(String text) {
      System.out.println(text); 
   }

   public static <T extends Printer>void print(String text) {
      T.printText(text);
   }

   public static void main(String[] args) {
      Printer.print("Hello World!");
  }

}

2 个答案:

答案 0 :(得分:7)

是的,有可能:

template <typename T>
void print(const std::string& text) 
{
    T::printText(text);
}

要确保PrinterT的基础,您可以将此编译时检查添加到函数中:

    static_assert(std::is_base_of<Printer, T>::value, "T must inherit from Printer");

答案 1 :(得分:4)

你可以这样做

struct A
{
    static void printMe()
    {
        std::cout << "A print \n";
    }
};

struct B
{
    static void printMe()
    {
        std::cout << "B print \n";
    }
};


template<typename T> void printer()
{
    T::printMe();
}

int main() {

    printer<A>();
    printer<B>();
    return 0;
}