网站大量收购独家精品文档,联系QQ:2885784924

c++12 类的静态成员、模板类).ppt

  1. 1、本文档共53页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第一部分---类的静态成员 静态数据 静态函数 静态数据 在类成员声明前加上 static 修饰即把该成员声明为该类的静态成员; 静态成员是该类所有对象共有的成员; 静态数据成员必须在定义第一个对象之前作为静态变量加以定义并初始化; 公有静态成员可以在无任何对象的情况下访问。 静态数据 静态数据成员在生成的每个类对象中并不占有存储空间,只是在每个类中分配有存储空间。该类的所有对象和外部函数(在允许的访问属性下)都可以直接访问这个空间。 类中声明静态成员后,不管具有的何种访问属性,都需要在类外定义并进行初始化。 若没有对其进行初始化,则自动被赋予初值0. class XX { //类的静态数据成员示例 int a; public: static int b; XX(int aa=0) { a=aa; b++; } int geta() {return a;} }; int XX::b=0; //类外定义并初始化 void main(){ coutXX::bendl; XX x(10),y(20); coutx.geta(),x.bendl; couty.geta(),y.bendl; } 静态函数 静态成员函数只能访问静态数据成员或调用静态函数成员。 若静态函数采用类外定义,则函数头不需要加static。 静态函数也只属于一个类,而不属于一个对象。 静态成员函数无this指针。 * * * * * 表很大,可调整打印方向、缩放比例 页面设置、设置工作表中的“顶端标题行” 表很大,可调整打印方向、缩放比例 页面设置、设置工作表中的“顶端标题行” * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * void InsertFront(const T item); void InsertRear(const T item); void InsertAt(const T item); void InsertAfter(const T item); T DeleteFront(void); void DeleteAt(void); T Data(void); void ClearList(void); }; #endif // LINKEDLIST_CLASS * * 链表类应用举例 #include iostream using namespace std; void main(void) { LinkedListint Link; int i, key, item; for (i=0;i 10;i++) { cinitem; Link.InsertFront(item); } 顺序访问的线性群体 cout List: ; Link.Reset(); while(!Link.EndOfList()) { cout Link.Data() ; Link.Next(); } cout endl; cout 请输入一个需要删除的整数: ; cin key; Link.Reset(); * while (!Link.EndOfList()) { if(Link.Data() == key) Link.DeleteAt(); Link.Next(); } cout List: ; Link.Reset(); while(!Link.EndOfList()) { cout Link.Data() ; Link.Next(); } cout endl; } * * 特殊的线性群体——栈 栈是只能从一端访问的线性群体,可以访问的这一端称栈顶,另一端称栈底。 an ┆ a2 a1 入栈 出栈 栈顶 栈底 特殊的线性群体——栈 * 栈的应用举例——函数调用 特殊的线性群体——栈 main{} 调fun(参数) 结束 fun(参数) 返回 ① ② ⑤ ⑦ ⑧ 参数 当前现场 返回地址 ③ ⑥ 入栈 当前现场 返回地址 出栈 参数 ④ 出栈 当前现场 返回地址 * 栈的应用举例——表达式处理 b a / a/b+c*d (a) t1 + a/b+c*d t1=a/b

文档评论(0)

xiaoga123 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档