预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共53页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

第十章第三讲:类的静态成员、模板类2第一部分---类的静态成员静态数据classMOD100{//类的静态函数成员示例 public: staticintadd(intx,inty){return(x+y)%100;} staticintsub(intx,inty){return(x-y)%100;} }; voidmain(){ cout<<MOD100::add(34,89)<<endl; cout<<MOD100::sub(34,199)<<endl; }静态数据classXX{//类的静态数据成员示例inta; public:staticintb;XX(intaa=0){a=aa;b++;}intgeta(){returna;} }; intXX::b=0;//类外定义并初始化 voidmain(){cout<<XX::b<<endl;XXx(10),y(20);cout<<x.geta()<<","<<x.b<<endl; cout<<y.geta()<<","<<y.b<<endl; }静态函数classMOD100{//类的静态函数成员示例 public: staticintadd(intx,inty){return(x+y)%100;} staticintsub(intx,inty); }; intMOD100::sub(intx,inty) {return(x-y)%100;}//函数外定义 ……10111213141516template<classT> //类模板:实现对任意类型数据进行存取 classStore {private: Titem;//用于存放任意类型的数据 inthaveValue;//用于标记item是否已被存入内容 public: Store(void);//默认形式(无形参)的构造函数 TGetElem(void);//提取数据函数 voidPutElem(Tx);//存入数据函数 }; //默认形式构造函数的实现 template<classT> Store<T>::Store(void):haveValue(0){}template<classT>//提取数据函数的实现 TStore<T>::GetElem(void) {//如果试图提取未初始化的数据,则终止程序 if(haveValue==0) {cout<<"Noitempresent!"<<endl; exit(1); } returnitem;//返回item中存放的数据 } template<classT>//存入数据函数的实现 voidStore<T>::PutElem(Tx) {haveValue++;//将haveValue置为TRUE,表示item中已存入数值 item=x;//将x值存入item }voidmain(void) {Studentg={1000,23}; Store<int>S1,S2; Store<Student>S3; Store<double>D; S1.PutElem(3); S2.PutElem(-7); cout<<S1.GetElem()<<""<<S2.GetElem()<<endl; S3.PutElem(g); cout<<"Thestudentidis"<<S3.GetElem().id<<endl; cout<<"RetrievingobjectD"; cout<<D.GetElem()<<endl;//输出对象D的数据成员 //由于D未经初始化,在执行函数D.GetElement()时出错 }202122232425262728template<classT> classLinkedList {private: Node<T>*front,*rear; Node<T>*prevPtr,*currPtr; intsize; intposition; Node<T>*GetNode(constT&item, Node<T>*ptrNext=NULL); voidFreeNode(Node<T>*p); voidCopyList(constLinkedList<T>&L);public: LinkedList(void); LinkedList(constLinkedList<T>&L); ~LinkedList(void); LinkedList<T>&operator= (constLinkedList<T>&L); intListSize(void)const; intListEmpty(void)const; voidReset(intpos=0); voidNext(void); intEndOfList(void)const; intCurre