江西师范大学C++面向对象程序设计课件第9章 群体类与群体数据组织.ppt

江西师范大学C++面向对象程序设计课件第9章 群体类与群体数据组织.ppt

  1. 1、本文档共77页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
本章主要内容 模板 群体类 群体数据的组织 第一部分:模板 函数模板 类模板 函数模板 函数模板可以用来创建一个通用功能的函数,以支持多种不同形参,进一步简化重载函数的函数体设计。 声明方法: template class 标识符 函数声明 求绝对值函数的模板 #includeiostream using namespace std; templateclass T T abs(T x) { return x0?-x:x; } int main() { int n=-5; double d=-5.5; coutabs(n)endl; coutabs(d)endl; } 求绝对值函数的模板分析 编译器从调用abs()时实参的类型,推导出函数模板的类型参数。例如,对于调用表达式abs(n),由于实参n为int型,所以推导出模板中类型参数T为int。 当类型参数的含义确定后,编译器将以函数模板为样板,生成一个函数: int abs(int x) { return x0?-x:x; } 类模板的作用 使用类模板使用户可以为类声明一种模式,使得类中的某些数据成员、某些成员函数的参数、某些成员函数的返回值,能取任意类型(包括基本类型的和用户自定义类型)。 类模板的声明 类模板: template 模板参数表 class 类名 {类成员声明} 如果需要在类模板以外定义其成员函数,则要采用以下的形式: template 模板参数表 类型名 类名T::函数名(参数表) 例9-2 类模板应用举例 #include iostream #include cstdlib using namespace std; // 结构体Student struct Student { int id; //学号 float gpa; //平均分 }; template class T //类模板:实现对任意类型数据进行存取 class Store { private: T item; //用于存放任意类型的数据 int haveValue; //用于标记item是否已被存入内容 public: Store(void); //默认形式(无形参)的构造函数 GetElem(void); //提取数据函数 void PutElem(T x);//存入数据函数 }; // 默认形式构造函数的实现 template class T StoreT ::Store(void): haveValue(0) {} template class T // 提取数据函数的实现 T StoreT ::GetElem(void) { // 如果试图提取未初始化的数据,则终止程序 if (haveValue == 0) { cout No item present! endl; exit(1); } return item; // 返回item中存放的数据 } template class T // 存入数据函数的实现 void StoreT ::PutElem(T x) { // 将haveValue 置为 TRUE,表示item中已存入数值 haveValue++; item = x; // 将x值存入item } int main() { Student g= {1000, 23}; Storeint S1, S2; StoreStudent S3; Storedouble D; S1.PutElem(3); S2.PutElem(-7); cout S1.GetElem() S2.GetElem()endl; S3.PutElem(g); cout The student id is S3.GetElem().idendl; cout Retrieving object D ; cout D.GetElem() endl; //输出对象D的数据成员 // 由于D未经初始化,在执行函数D.GetElement()时出错 } 第二部分:群体数据 线性群体 线性群体的概念 直接访问群体--数组类 顺序访问群体--链表类 栈类 队列类 群体的概念 群体是指由多个数据元素组成的集合体。群体可以分为两个大类:线性群体和非线性群体。 线性群体中的元素按位置排列有序,可以区分为第一个元素、第二个元

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档