我想执行以下操作:
template <typename T>
struct foo
{
template <typename S>
friend struct foo<S>;
private:
// ...
};
但我的编译器 (VC8) 卡住了:
but my compiler (VC8) chokes on it:
error C3857: 'foo<T>': multiple template parameter lists are not allowed
我想要所有 T 的 template struct foo 朋友的所有可能的实例化.
I'd like to have all possible instantiations of template struct foo friends of foo<T> for all T.
我该如何完成这项工作?
How do I make this work ?
这个
template <typename T>
struct foo
{
template <typename>
friend struct foo;
private:
// ...
};
似乎可以编译,但正确吗?朋友和模板的语法非常不自然.
seems to compile, but is it correct ? Friends and templates have very unnatural syntax.
template<typename> friend class foo
然而,这将使所有模板彼此成为朋友.但我想这就是你想要的吗?
this will however make all templates friends to each other. But I think this is what you want?
这篇关于如何将模板化结构/类声明为朋友?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
std::reference_wrapper 和简单指针的区别?Difference between std::reference_wrapper and simple pointer?(std::reference_wrapper 和简单指针的区别?)
常量之间的区别.指针和引用?Difference between const. pointer and reference?(常量之间的区别.指针和引用?)
c++ - 如何从指向向量的指针访问向量的内容?How to access the contents of a vector from a pointer to the vector in C++?(c++ - 如何从指向向量的指针访问向量的内容?)
*& 的含义和**&在 C++ 中Meaning of *amp; and **amp; in C++(*amp; 的含义和**amp;在 C++ 中)
为什么我不能对普通变量进行多态?Why can#39;t I do polymorphism with normal variables?(为什么我不能对普通变量进行多态?)
取消引用已删除的指针总是会导致访问冲突?Dereferencing deleted pointers always result in an Access Violation?(取消引用已删除的指针总是会导致访问冲突?)