nested friend
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nested friend相关的知识,希望对你有一定的参考价值。
#include "stdafx.h" #include <iostream> #include <cstring> using namespace std; const int sz=20; struct Holder{ private: int a[sz]; public: void initialize(); struct Pointer; friend Pointer; struct Pointer{ private: Holder *h; int *p; public: void initialize(Holder *h); void next(); void previous(); void top(); void end(); int read(); void set(int i); }; }; void Holder::initialize(){ memset(a,0,sz*sizeof(int)); } void Holder::Pointer::initialize(Holder *rv){ h=rv; p=rv->a; } void Holder::Pointer::next(){ if(p<&(h->a[sz-1]))p++; } void Holder::Pointer::previous(){ if(p>&(h->a[0]))p--; } void Holder::Pointer::top(){ p= &(h->a[0]); } void Holder::Pointer::end(){ p= &(h->a[sz-1]); } int Holder::Pointer::read(){ return *p; } void Holder::Pointer::set(int i){ *p = i; } int _tmain(int argc, _TCHAR* argv[]) { Holder h; Holder::Pointer hp,hp2; int i; h.initialize(); hp.initialize(&h); hp2.initialize(&h); for(i=0;i<sz;i++){ hp.set(i); hp.next(); } hp.top(); hp2.end(); for(i=0;i<sz;i++){ cout<<hp.read()<<" "<<hp2.read()<<endl; hp.next(); hp2.previous(); } return 0; }
以上是关于nested friend的主要内容,如果未能解决你的问题,请参考以下文章