模板类的前置声明



template<class T>
class Array;

template<class T>
class Pointer;

template<class T>
class Array_data
{
 friend class Array<T>;
 friend class Pointer<T>;

 Array_data(unsigned int n)
  :data(new T[n])
  ,sz(n)
  ,use(1)
 {

 }

 ~Array_data(){ delete data; }

 const T& operator[](unsigned n)const
 {
  if ( n >= sz )
  {
   throw "Array subScript out of range.";
  }

  return (*data)[n];
 }

 T& operator[](unsigned n)
 {
  if ( n >= sz )
  {
   throw "Array subScript out of range.";
  }

  return (*data)[n];
 }

 Array_data(const Array_data&);
 Array_data& operator=(const Array_data&);
private:
 T* data;
 unsigned int sz;
 int use;
};

template<class T>
class Array
{
public:
 Array(unsigned int n):data(new Array_data<T>(n))
 {

 }
 ~Array()
 {
  if (--data->use == 0)
  {
   delete data;
  }
 }

 const T& operator[](unsigned int n)const
 {
  return (*data)[n];
 }

 T& operator[](unsigned int n)
 {
  return (*data)[n];
 }

private:
 Array(const Array&);
 Array& operator=(const Array&);
 Array_data<T>* data;
};

template<class T>
class Pointer /*: public Ptr_to_const<T>*/
{
public:
 Pointer(Array<T>& a,unsigned n):ap(a.data),sub(n){ ++ap->use;}
 Pointer():ap(0),sub(0)()
  Pointer(const Pointer<T>& p)
  :ap(p.ap)
  ,sub(p.sub)
 {
  if (p.ap)
  {
   ++ap->use;
  }
 }


private:
 Array_data<T>* ap;
 unsigned sub;
};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当我们声明一个模板时,有时候我们需要让某个能够访问到这个模板类的私有成员或保护成员。这时我们就可以使用友元来实现。 下面是一个声明模板的友元的示例代码: ``` template<typename T> class MyTemplateClass { friend class MyFriendClass; public: MyTemplateClass(T value); private: T m_value; }; template<typename T> MyTemplateClass<T>::MyTemplateClass(T value) : m_value(value) {} class MyFriendClass { public: template<typename T> void printValue(const MyTemplateClass<T>& obj) { std::cout << "The value is: " << obj.m_value << std::endl; } }; int main() { MyTemplateClass<int> obj(42); MyFriendClass friendObj; friendObj.printValue(obj); return 0; } ``` 在这个示例代码中,我们声明了一个模板`MyTemplateClass`,并且声明了一个友元`MyFriendClass`。通过`friend class MyFriendClass;`语句,我们将`MyFriendClass`声明为`MyTemplateClass`的友元,这意味着`MyFriendClass`可以访问到`MyTemplateClass`的私有成员或保护成员。 在`MyFriendClass`中,我们定义了一个模板函数`printValue`,该函数接受一个`MyTemplateClass`型的对象作为参数,并打印出这个对象的私有成员`m_value`。在`main`函数中,我们实例化了一个`MyTemplateClass`对象,并创建了一个`MyFriendClass`对象`friendObj`,然后通过`friendObj.printValue(obj)`调用了`MyFriendClass`的`printValue`函数,输出了`MyTemplateClass`对象的私有成员值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值