问题描述
- C++怎么把模板类设置为友元?
-
求好心人解答~~
1.怎么把模板类设置为友元??模板函数 模板类。
2.设置的时候 需要具体化吗?? 是不是 可以具体化 也可以不具体??
解决方案
参考:http://www.cnblogs.com/li-peng/p/3512887.html
解决方案二:
根据《C++ Primer》第三版16.4节的叙述,C++类模板友元分为以下几种情况
1.非模板友元类或友元函数。 书上给了一个例子:
class Foo{
void bar();
};
template
class QueueItem{
friend class foobar;
friend void foo();
friend void Foo::bar();
//....
};
很简单,跟非模板类没什么区别,有一点需要注意,如果要把函数和类生命为友元,前面不需要声明或定义。但是如果要把类成员函数声明为友元,则前面必须有类的定义(注意不是声明,是定义),因为一个类成员只能由该类的定义引入 。
2.绑定的友元类模板或函数模板。 例子如下:
template
class foobar{ ...};
template
void foo(QueueItem);
template
class Queue{
void bar();
//...
};
template
class QueueItem {
friend class foobar ;
friend void foo (QueueItem);
friend void Queue ::bar();
//...
};
需要注意两点:
a.与非模板函数或类不同,模板函数或类声明为友元之前必须在前面声明过 ,否则无法通过编译。
b.注意红字部分,那几个Type不能少。比如对于函数foo,如果少了的话编译器会将其作为非模板函数对待,也就是说,对于QueueItem,编译器会查找void foo(QueueItem),而对templatevoid foo(QueueItem)视而不见,如果没找到非模板函数则会报错。
3.非绑定友元类模板或函数模板。 举例如下:
template
class QueueItem {
template
friend class foobar;
template<class T>
friend void foo(QueueItem<T>);
template<class T>
friend void Queue<T>::bar();
//...
};
解决方案三:
根据《C++ Primer》第三版16.4节的叙述,C++类模板友元分为以下几种情况
1.非模板友元类或友元函数。 书上给了一个例子:
class Foo{
void bar();
};
template
class QueueItem{
friend class foobar;
friend void foo();
friend void Foo::bar();
//....
};
很简单,跟非模板类没什么区别,有一点需要注意,如果要把函数和类生命为友元,前面不需要声明或定义。但是如果要把类成员函数声明为友元,则前面必须有类的定义(注意不是声明,是定义),因为一个类成员只能由该类的定义引入 。
2.绑定的友元类模板或函数模板。 例子如下:
template
class foobar{ ...};
template
void foo(QueueItem);
template
class Queue{
void bar();
//...
};
template
class QueueItem {
friend class foobar ;
friend void foo (QueueItem);
friend void Queue ::bar();
//...
};
需要注意两点:
a.与非模板函数或类不同,模板函数或类声明为友元之前必须在前面声明过 ,否则无法通过编译。
b.注意红字部分,那几个Type不能少。比如对于函数foo,如果少了的话编译器会将其作为非模板函数对待,也就是说,对于QueueItem,编译器会查找void foo(QueueItem),而对templatevoid foo(QueueItem)视而不见,如果没找到非模板函数则会报错。
3.非绑定友元类模板或函数模板。 举例如下:
template
class QueueItem {
template
friend class foobar;
template<class T>
friend void foo(QueueItem<T>);
template<class T>
friend void Queue<T>::bar();
//...
};
解决方案四:
模板类在作为友元之前,一定要出现一次声明像下面这样做:
template
class ChainList;
template
class Node{
friend class ChainList;
public:
T data;
T *link;
};