我正在尝试使用可变参数模板来指定好友类。我尝试使用以下语法,但它不起作用。
template <class... Args>
struct A {
friend Args...;
};
我尝试编写一些解决方法,但似乎并非如此简单,因为友谊不是传递和继承的。所以问题是,是否有正确的语法或任何解决方法使Args中的每个班级成为A的朋友?
答案 0 :(得分:3)
以下CRTP变体可能足以供您使用:
template<typename Arg> class Abase
{
friend Arg;
virtual int foo(int) = 0; // this is the private interface you want to access
public:
virtual ~Abase() {}
};
template<typename... Args> class A:
public Abase<Args> ...
{
virtual int foo(int arg) { return frobnicate(arg); }
// ...
}
然后,您在Args中传递的每个类都可以通过相应的Abase
基类访问该私有接口,例如
class X
{
public:
// assumes X is in the Args
template<typename Args ...> int foo(A<Args...>* p)
{
Abase<X>* pX = p; // will fail if X is not in Args
return pX->foo(3); // works because X is friend of Abase<X>
}
};