以下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!");
}
}
答案 0 :(得分:7)
是的,有可能:
template <typename T>
void print(const std::string& text)
{
T::printText(text);
}
要确保Printer
是T
的基础,您可以将此编译时检查添加到函数中:
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;
}