当前位置 —论文本科论文— 范文

关于模板方面论文范文参考文献,与如何理解C++模板相关毕业论文怎么写

本论文是一篇关于模板方面毕业论文怎么写,关于如何理解C++模板相关毕业论文提纲范文。免费优秀的关于模板及设计类及什么是方面论文范文资料,适合模板论文写作的大学硕士及本科毕业论文开题报告范文和学术职称论文参考文献下载。

首先谈一下什么是模板.模板就是为解决某一类问题,从而抽象了这类问题的具体共性,为这类问题提供一种通用的解决方法.工作中有很多这样的例子,比如我们熟知的MicrosoftOffice中的模板,它给我们的工作带来了很多便利,改变了每件事都得从头编码的做事方法,使得代码重用变得如此简单.

C++模板的基础讨论

C++模板的思想也是基于此,它抽象了具体的型别,实现了共性逻辑,为一类问题提供了统一的泛型接口.模板机制使得编程者在定义类和函数时能以类型作为参数,并且模板只依赖于实际使用时的传入参数,不关心能被用作参数的那些不同类型之间的任何联系.刚刚接触C++模板时,可能会感觉它不就是C的#define宏吗,只是在这里换了一种说法,无非是“新瓶装旧酒”啊.但是如果你对它感兴趣,再深入地理解一下,相信它会带给你很大的惊喜的.当前,C++模板已经变成了通用编程的基础,是标准模板库(STL)的基石.它使得用户接口更简单,表达更清晰.

C++是一门静态的语言,它是强类型检查的,所以代码不可能在运行时再编译生成.而C++模板的技术核心也在于编译期的代码解释和执行期的零成本.虽然这点同#define宏比较类似,但是它实现更简单,更不容易产生错误,使得代码看起来更具美感,并且它提供函数返回值,可以进行代码调试,可以进行编译期的变量类型检查等等,这些都不是#define宏能比拟的.下面让我们先看一下C++中如何定义一个模板.

怎么去定义一个模板

C++中有两种模板,一种是类模板,一种是函数模板,函数模板也可以在类模板中使用.因为模板是编译期生成代码的,所以一般我们都把模板代码放到一个头文件中声明定义.首先,我们看一下类模板.

templateclassClassName

{

enum{ssize等于50},

Tm_Stack[ssize],

intm_Top_postion,

public:

ClassName():m_Top_postion(0){}

voidpush_into(constT&i){


怎么写模板本科毕业论文
播放:35099次 评论:3827人

m_Stack[m_Top_postion++]等于i,

}

Tpop_up(){

returnm_Stack[--m_Top_postion],

}

intsize(){

returnm_Top_postion,

}

},

template这个关键字告知编译器,随后的类定义ClassName将需要一个或更多的类型.这里的T是需要替换的类型参数,你可以指定T为任何你所需要的有意义的类型,比如整型、结构体类型,或者是一个模板类型等.(关于类模板中的常量以及详细的模板的语法,请参照C++语言程序设计者BjarneStroustrup的大作《C++程序设计语言》)

其次,是函数模板.它用于创建基于泛型为参数的函数.

templateintGetsize(std::vector¶m),

这里的template和class的意义同类模板的一样.但是在函数模板中模板参数必须出现在函数参数中.

模板的实例化

C++模板提供了对源代码重用的方法,而不像是继承跟组合提供的对目标代码的重用方式.这使得处理问题的耦合更小,更简单,接口更加丰富,代码量更少.编译器会根据具体的参数,生成具体问题的解法的特定代码,这就是模板的实例化.下面让我们通过一个例子来认识一下模板代码是怎么生成具体的特定代码的.


本文出处 http://www.sxsky.net/benkelunwen/060149456.html

templateclassClassName{

Tm_data[size],

intm_pos,

public:

ClassName():m_pos(0){}

voidput_into(constT&t)

{

m_data[m_pos++]等于t,

}

},

下面我们定义一个变量ClassNamev,,在这里T的类型变为int,整形参数size没有改变而是使用了模板中的默认值60.这样编译器产生的类代码如下.

classClassName{

intm_data[60],

intm_pos,

public:

ClassName():m_pos(0){}

voidput_into(constT&t)

{

m_data[m_pos++]等于t,

}

},

这就是模板参数的实例化过程,根据不同的参数生成了特定的类.函数模板的原理同类模板相同,这里就不在赘述了.

模板的特化

一个模板描述了某个范围内的一族函数或类.当给定模板参数时,这些模板参数决定了这一族函数或类中的独一无二的特例,这样的过程结果被称为特化.当然模板实例化也是特化的过程.特化分为全特化和半特化,但是函数模板不能半特化,必须一次性的全特化.下面我们分别看看这两中情况.

首先看看全特化,全特化使用了template<>来标识.

templateconstT&pare(constT&a,constT&b){return(a>b)a:b,

}

//Anexplicitspecializationofthemaxtemplate

template<>

constchar*const&pare(constchar*const&a,constchar*const&b){

return(strlen(a)>strlen(b))a:b,

}

这样我们使用模板时,例如pare<>(s1,s2)就是使用全特化后的模板生成的最终代码.pare(4,5)就是使用未全特化的模板生成的最终代码.

再看一个例子:

templateclassCAssert,

template<>classCAssert{},

在这个例子中实现的部分跟省略的一样多,但是它可以工作得很好.它的全特化只是实现了bool型别为true的情况,这样我们就能使用它在代码中进行静态断言.

再来看一下半特化,半特化又叫偏特

关于如何理解C++模板的毕业论文提纲范文
关于模板方面论文范文参考文献
化.这种特化方式只是针对于类模板.故名思议,半特化只是部分地特化了模板,约束了符合用户期望的行为的模板参数,其他参数仍然维持其泛型的性质.编译器在生成模板代码时会查找出最匹配的定义,来进行实例化.模板的半特化有很多巧妙的应用,它很好地处理了一些分支问题.下面就以loki库中的一个例子来看看这种迷人的用法.

比如你需要向一个容器里面插入变量,有时是T,有时是T*.Loki库的实现如下.

template

structSelect

{

TypedefTresult,

},

template

structSelect

{

TypedefUresult,

},

Select::result即为需要的型别,只需要根据boolval的值决定.

模板的递归模式

这种模板的递归方式能使得每个派生类都派生于一个唯一的基类,这个基类使用了它本身作为模板参数.从理论上来说这会产生无休止的递归循环,使得编译器无法推断出派生类及其基类的具体的型别大小等,但是只要基类中的数据成员不含有与模板型别相关的依赖,模板是可以被实例化出来的.当程序设计者需要派生类具有某些性质,但是这些性质的实现通过继承又不能很好的处理时,此时可以考虑模板的递归模式.下面我们看一下具体的例子.

templateclassCounted{

staticsize_tcount,

public:

Counted(){++

1 2

关于模板方面论文范文参考文献,与如何理解C++模板相关毕业论文怎么写参考文献资料:

本科自考有哪些专业

电大本科论文

小自考本科有用吗

自考本科费用

黑龙江自考本科专业

本科生写论文

高中可以自考本科吗

如何自考本科

中专函授本科

本科自考报考

如何理解C++模板WORD版本 下载地址