- 1、本文档共41页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第16章c模板
(2)类模板的成员函数既可以在类体内进行说明(定义),也可以在类体外进行说明(定义)。 在类体外定义类模板成员函数的一般格式如下: template 模板参数表 函数类型 类模板名 模板参数名字表::成员函数名(函数参数表) { ... //成员函数的函数体 }; (3)类模板的参数。 设计C++语言类模板时,首先设计出所需要的若干个模板参数,并规定各参数的使用含义。 模板的定义体现了这个集合中的类的共性,而模板参数则标识出集合中类的区别。 类模板可能是依赖于两个类型参数的,可以定义一种类模板,表示不同维数,不同元素类型的矩阵类。这样的类模板的模板参数可能除了一个类型之外,还有两个整型参数,等等。 16.3.3 使用类型参数和普通参数的 类模板 // program16_5.cpp #include iostream.h #include string.h template class T, int i class TestClass //类模板TestClass,使用类型形参T及普通形参i { public: T buffer[i]; //T类型的buffer数组,数组大小由普通形参i的值指定 T getData(int j); //getData函数,负责返回T类型的buffer(数组)的第j个分量 }; template class T, int iT TestClassT, i::getData(int j) //在类体外定义成员函数getData { return *(buffer+j); //返回buffer(数组)的第j个分量 }; int main() //创建类模板TestClass的实例对象并对它们进行使用 { TestClasschar, 5 ClassInstA; char cArr[6]=abcde; strcpy(ClassInstA.buffer, cArr); //为类对象ClassInstA的buffer数组赋值 for(int i=0; i5; i++) //调用类成员函数getData取出buffer数组各元素值并输出:a b c d e { char res=ClassInstA.getData(i); coutres ; } coutendl; TestClassdouble, 6 ClassInstF; double fArr[6]={12.1, 23.2, 34.3, 45.4, 56.5, 67.6}; for(i=0; i6; i++) //为类对象ClassInstF的buffer数组赋值 ClassInstF.buffer[i]=fArr[i]-10; for(i=0; i6; i++)//调用getData取出buffer数组各元素值并输出:2.1 13.2 24.3 35.4 46.5 57.6 double res=ClassInstF.getData(i); { coutres “; } coutendl; return 0;} 16.4 关于类模板的若干问题说明 16.4.1静态成员及友元 16.4.2特例版本 16.4.3 按不同方法来派生类模板 16.4.1静态成员及友元 (1)类模板的静态成员 (2)类模板的友元 (1)类模板的静态成员 类模板也允许有静态成员。对于一个类模板的每一个实例化类,其所有的对象共享其静态成员。例如: templateclass Tclass C //类模板的静态成员t { static T t; }; 类模板的静态成员在模板定义时是不会被创建的,其创建是在类的实例化之后。 (2)类模板的友元 类模板定义中允许包含友元。 (a)该友元函数为一般函数,则它将是该类模板的所有实例化类的友元函数。 (b)该友元函数为一函数模板,但其类型参数与类模板的类型参数无关。 (c)更复杂的情形是,该友元函数为一函数模板,且它与类模板的类型参数有关。 16. 4. 2 特例版本 类模板的使用十分方便,但大多数类模板不能任意进行实例化。也就是说类模板的类型参数往往在实例化时不允许用任意的类(类型)作为“实参”。C++语言中没有对模板的“实参”类型进行检查的机制,它仅仅是通过实际操作中发生语法错误时,才能指出实例化的错误。 16. 4. 3 按不同方法来派生类模板 (1)一般类(其中不使用类型参数的类)作基类,派生出类模板(其中要使用类型参数)。 (2)类模板作基类,派生出新的类模板。但仅基类中用到类型参数T(而派生的类模板中不使用T)。 (3)类模板作基类,派生出新的类模板,且基类与派生类中均使用同
文档评论(0)