1,typename关键字:
(1)若一个模板代码内部的某个类型被模板参数所限定,则必须使用typename关键字作为前缀声明.
注:typename关键字仅仅用于模板代码中.
(2)一定不能认为typename创建了一个新类型名.
typename Seq<T>::iterator ite;
typedef typename Seq<T>::iterator ite;//这才是创建一个新类型名.
实例代码:
#include <iostream>
#include <vector>
#include <list>
#include <algorithm>
using namespace std;
class SkipGen
{
int start,step;
public:
SkipGen(int m=1,int n=3):start(m),step(n){}
int operator()()
{
int temp=start;
start+=step;
return temp;
}
};
template<class T,template<class U,class=allocator<U> > class Seq>
void printSeq(const Seq<T>& seq) //const对应const
{
typename Seq<T>::const_iterator ite;
for(ite=seq.begin();ite!=seq.end();ite++)
{
if(ite==seq.begin())
cout<<*ite;
else
cout<<" "<<*ite;
}
cout<<endl;
}
int main()
{
vector<int> vec(10);
generate(vec.begin(),vec.end(),SkipGen(1,3));
printSeq(vec);
list<int> lst(10);
generate(lst.begin(),lst.end(),SkipGen(2,2));
printSeq(lst);
return 0;
}
2,template关键字:
"<"有时候代表小于号,template告诉编译器紧接着的是一个模板名称.
实例代码:
#include <iostream>
#include <bitset>
#include <cstddef>
using namespace std;
template<class charT,size_t N>
basic_string<charT> bitSetString(bitset<N> bs)
{
//这里必须使用template解析.
return bs.template to_string<charT,char_traits<charT>,allocator<charT> >();
}
//注:to_string本身就是一个模板函数,但是没有使用默认参数.
//basic_string使用了默认参数
//这样就可以用bitSetString<char>(bs)替代bs. template to_string<char,char_traits<char>,allocator<char> >()
int main()
{
bitset<10> bs;
bs.set(1),bs.set(5);
cout<<bs<<endl;
string str1=bitSetString<char>(bs);
cout<<str1<<endl;
string str2=bs.to_string<char,char_traits<char>,allocator<char> >();
cout<<str2<<endl;
return 0;
}
3,模板类的成员是模板类.
注:成员模板函数不能被声明为virtual类,这是因为编译器解析一个类时,需要知道虚函数表的大小,如果允许模板虚成员函数,则必须提前知道这些模板成员在哪里调用.
实例代码:
#include <iostream>
using namespace std;
template<class T>
class Outer
{
public:
template<class U>
class Inner
{
public:
void f();
};
};
template<class T>
template<class U>
void Outer<T>::Inner<U>::f()
{
cout<<"Outer type=="<<typeid(T).name()<<endl;
cout<<"Inner type=="<<typeid(U).name()<<endl;
cout<<"class Inner=="<<typeid(*this).name()<<endl;
}
int main()
{
Outer<int>::Inner<bool> inner;
inner.f();
return 0;
}
分享到:
相关推荐
深入理解JavaScript系列(2):揭秘命名函数表达式 深入理解JavaScript系列(3):全面解析Module模式 深入理解JavaScript系列(4):立即调用的函数表达式 深入理解JavaScript系列(5):强大的原型和原型链 ...
深入理解JavaScript系列(41):设计模式之模板方法 深入理解JavaScript系列(42):设计模式之原型模式 深入理解JavaScript系列(43):设计模式之状态模式 深入理解JavaScript系列(44):设计模式之桥接模式 ...
《深入理解C++11》讲解了C++11 lambda、decltype、auto、可变长模板参数、智能指针和原子操作等特性......
模板中使用class和typename的区别 还没翻几页,当看到这段代码的时候就楞了一下。印象中上次也是看到这里一下子没弄懂,还特地搜索过的。结果再来一遍的时候还是忘了。果然好记性不如烂笔头,赶紧写篇博客mark一下。 ...
Magento 模块开发教程 请求分发与控制器 布局、块和模板 模型和ORM基础 高级Magento模型
深入理解机算计系统英文课件PPT
Angular2的模板用来显示组件外观,作为视图所用,用法和html语法基本一致,最简单的Angular2的模板就是一段html代码。Angular模板语法主要包括以下几个部分: l 直接绑定 l 插值表达 l 属性绑定 l 事件绑定 l 双向...
深入理解计算机系统课件,CSAPP
该文档是根据博客园汤姆大叔的深入理解JavaScript系列(http://www.cnblogs.com/TomXu/archive/2011/12/15/2288411.html)博文整理而成,主要内容包括: 1.编写高质量JavaScript代码的基本要点 2.揭秘命名函数...
《深入理解C++11:C++11新特性解析与应用》主要内容:国内首本全面深入解读C++11新标准的专著,由C++标准委员会代表和IBM XL编译器中国开发团队共同撰写。不仅详细阐述了C++11标准的设计原则,而且系统地讲解了C++11...
有助于你深入地学习,理解c++类模板相关技术。由简单到复杂逐渐深入学习。
更深入理解模板匹配技术,能够独立根据已知算法(相关匹配(Correlation Matching)、基于Hausdorff距离匹配方法 及考虑对场景图象距离变换(Distance Transform)的Hausdorff距离匹配方法)在MATLAB下编程实现相关...
2类模板;3模板形参的默认实参;4类模板别名与模板特例 类模板在实例化时必须显式地指明数据类型,编译器不能根据给定的数据推演出数据类型。 对于强类型的语言,变量的类型从始至终都是确定的、不变的,编译器在...
通过此文档 可以全面 深入理解 PHP内核的设计、程序逻辑。有兴趣的朋友可以研究研究。
深入理解Magento-第三章 – 布局,块和模板 深入理解Magento-第四章 – 模型和ORM基础 深入理解Magento-第五章 – Magento资源配置 深入理解Magento-第六章 – 高级Magento模型 深入理解Magento-第七章 – ...
大致实现了STL中的线性表基本功能,通过对比C语言实现线性表的顺序存储可以更好的理解面向对象编程和面向过程的区别,更加深入的理解C语言和C++语言的区别。相关的文章可以在我的主页算法与数据结构专栏查看。
深入理解Smarty模版引擎原理的最好教程,采用最简单最基本的功能写成的Smarty模板引擎,很容易就能理解Smarty的工作原理。
介绍了箭头函数、解构、模板字面量以及其他语法方面的新元素,还全面展示了ES6引入的流程控制机制,以及如何高效地简化自己的代码。本书的讨论还涉及 ES6 内置的新