导航:首页 > 使用方法 > c模板类的使用方法

c模板类的使用方法

发布时间:2022-12-29 00:15:40

1. c++中如何使用类模板

template<typename T>//方法模板
T add(T const&a,const T&b){//两个const限定等价
return a+b;
}//注意,这里没有分号,因为这是方法

template<typename T>//结构体模板
struct S{
T s;
};//注意,这里有分号,因为这是结构体

template<typename T>//类模板
class A{
public:
S<T> s;//使用了结构体模板
void set(T s0);
};//注意,这里有分号,因为这是类

template<typename T>//实现类里面的方法
void A<T>::set(T s0){//注意这一行的格式
s.s=s0;
}
//注意,这个方法只有到被使用时才会开始实例化,不过可以显式实例化让它一开始就实例化

int main(){
template A<int>;//显式实例化
template A<double>;
int a=1,b=2;
double c=3.3;
add(a,b);//正确
add(a,c);//错误,模板参数类型是严格匹配的,不可能进行隐式转换
A<int> a;//使用了类模板
a.set(5);
cout<<a.s.s;//输出5
}

以上为类型参数模板
下面为值参数模板
template<unsigned int N>
class bitset;
。。。
bitset<100> b1;

模板定做,即针对某一类型的参数特别处理,比如加法并不是对所有的类型都适用,对于char*类型就要定做下
//先定义模板
template<typename T>
class A{
public:
T s;
void show();
}
template<typename T>
void A<T>::show(){
cout<<s<<endl;
}
//然后模板定做
class B{}//定义一个类型
template<>//不要填入类型
class A<B>{//直接使用自己需要的类型
public:
B s;//相应改为自己需要的类型
void show();
}
void A<B>::show(){//注意格式,这里没有template语句
cout<<s<<endl;
}

模板参数可以有多个
template<typename T1,typename T2>
class A{}

只定做T2而不定做T1就叫局部定做,如:
template<typename T1>
class A<T1,T1>{}

template<typename T1>
class A<T1,B>{}

2. C++中vector+模板的使用方法

(1)vector< 类型 > 标识符 ;
(2)vector< 类型 > 标识符(最大容量) ;
(3)vector< 类型 > 标识符(最大容量,初始所有值);
(4) int i[4] = {12,3,4,5};
vector< 类型 > vi(i , i+2); //得到i索引值为3以后的值 ;

(5)vector< vector<int> > //vi 定义2维的容器;记得一定要有空格,不然会报错
vector< int > line
// 在使用的时候一定要首先将vi个行进行初始化;
for(int i = 0 ; i < 10 ; i ++)
{
vector.push_back(line);
}
/// 个人认为使用vector定义二维数组很好,
因为是长度可以不预先确定。很好。
(6)C++ Vector排序
vector< int > vi ; vi.push_back(1); vi.push_back(3); vi.push_back(0); sort(vi.begin() , vi.end()); /// /小到大 reverse(vi.begin(),vi.end()) /// 从大道小

(7)顺序访问
vector < int > vi ; for( int i = 0 ; i < 10 ; i ++) { vector.push_back(i); } for(int i = 0 ; i < 10 ; i ++) /// 第一种调用方法 { cout <<vector[i] <<" " ; } for(vector<int>::iterator it = vi.begin() ; it !=vi.end() ; it++) ///第二种调用方法 { cout << *it << " " ; }

(8)寻找
vector < int > vi ; for( int i = 0 ; i < 10 ; i ++) { vector.push_back(i); } vector < int >::interator it = find(vi.begin() , vi.end,3) ; cout << *it << endl ; ///返回容器内找到值的位置。

(9)使用数组对C++ Vector进行初始化
int i[10] ={1,2,3,4,5,6,7,78,8} ; ///第一种 vector<int> vi(i+1,i+3); ///从第2个元素到第三个元素 for(vector <int>::interator it = vi.begin() ; it != vi.end() ; it++) { cout << *it <<" " ; }

(10) 结构体类型
struct temp { public : string str ; public : int id ; }tmp int main() { vector <temp> t ; temp w1 ; w1.str = "Hellowor" ; w1.id = 1 ; t.push_back(t1); cout << w1.str << "," <<w1.id <<endl ; return 0 ; }
vector类为内置数组提供了一种替代表示,与string类一样 vector 类是随标准
C++引入的标准库的一部分 ,为了使用vector 必须包含相关的头文件 。

3. C++中函数模板怎么

1.函数模板的声明和模板函数的生成

1.1函数模板的声明
函数模板可以用来创建一个通用的函数,以支持多种不同的形参,避免重载函数的函数体重复设计。它的最大特点是把函数使用的数据类型作为参数。
函数模板的声明形式为:
template<typename 数据类型参数标识符>
<返回类型><函数名>(参数表)
{
函数体
}
其中,template是定义模板函数的关键字;template后面的尖括号不能省略;typename(或class)是声明数据类型参数标识符的关键字,用以说明它后面的标识符是数据类型标识符。这样,在以后定义的这个函数中,凡希望根据实参数据类型来确定数据类型的变量,都可以用数据类型参数标识符来说明,从而使这个变量可以适应不同的数据类型。例如:
template<typename T>
T fuc(T x, int y)
{
T x;
//……
}
如果主调函数中有以下语句:
double d;
int a;
fuc(d,a);
则系统将用实参d的数据类型double去代替函数模板中的T生成函数:
double fuc(double x,int y)
{
double x;
//……
}
函数模板只是声明了一个函数的描述即模板,不是一个可以直接执行的函数,只有根据实际情况用实参的数据类型代替类型参数标识符之后,才能产生真正的函数。
关键字typename也可以使用关键字class,这时数据类型参数标识符就可以使用所有的C++数据类型。
1.2.模板函数的生成
函数模板的数据类型参数标识符实际上是一个类型形参,在使用函数模板时,要将这个形参实例化为确定的数据类型。将类型形参实例化的参数称为模板实参,用模板实参实例化的函数称为模板函数。模板函数的生成就是将函数模板的类型形参实例化的过程。例如:
使用中应注意的几个问题:
⑴ 函数模板允许使用多个类型参数,但在template定义部分的每个形参前必须有关键字typename或class,即:
template<class 数据类型参数标识符1,…,class 数据类型参数标识符n>
<返回类型><函数名>(参数表)
{
函数体
}
⑵ 在template语句与函数模板定义语句<返回类型>之间不允许有别的语句。如下面的声明是错误的:
template<class T>
int I;
T min(T x,T y)
{
函数体
}
⑶ 模板函数类似于重载函数,但两者有很大区别:函数重载时,每个函数体内可以执行不同的动作,但同一个函数模板实例化后的模板函数都必须执行相同的动作。

2 函数模板的异常处理

函数模板中的模板形参可实例化为各种类型,但当实例化模板形参的各模板实参之间不完全一致时,就可能发生错误,如:
template<typename T>
void min(T &x, T &y)
{ return (x<y)?x:y; }
void func(int i, char j)
{
min(i, i);
min(j, j);
min(i, j);
min(j, i);
}
例子中的后两个调用是错误的,出现错误的原因是,在调用时,编译器按最先遇到的实参的类型隐含地生成一个模板函数,并用它对所有模板函数进行一致性检查,例如对语句
min(i, j);
先遇到的实参i是整型的,编译器就将模板形参解释为整型,此后出现的模板实参j不能解释为整型而产生错误,此时没有隐含的类型转换功能。解决此种异常的方法有两种:
⑴采用强制类型转换,如将语句min(i, j);改写为min(i,int( j));
⑵用非模板函数重载函数模板
方法有两种:
① 借用函数模板的函数体
此时只声明非模板函数的原型,它的函数体借用函数模板的函数体。如改写上面的例子如下:
template<typename T>
void min(T &x, T &y)
{ return (x<y)?x:y; }
int min(int,int);
void func(int i, char j)
{
min(i, i);
min(j, j);
min(i, j);
min(j, i);
}
执行该程序就不会出错了,因为重载函数支持数据间的隐式类型转换。
② 重新定义函数体
就像一般的重载函数一样,重新定义一个完整的非模板函数,它所带的参数可以随意。C++中,函数模板与同名的非模板函数重载时,应遵循下列调用原则:
• 寻找一个参数完全匹配的函数,若找到就调用它。若参数完全匹配的函数多于一个,则这个调用是一个错误的调用。
• 寻找一个函数模板,若找到就将其实例化生成一个匹配的模板函数并调用它。
• 若上面两条都失败,则使用函数重载的方法,通过类型转换产生参数匹配,若找到就调用它。
•若上面三条都失败,还没有找都匹配的函数,则这个调用是一个错误的调用。

阅读全文

与c模板类的使用方法相关的资料

热点内容
中式棉袄制作方法图片 浏览:57
五菱p1171故障码解决方法 浏览:852
男士修护膏使用方法 浏览:540
电脑图标修改方法 浏览:601
湿气怎么用科学的方法解释 浏览:532
910除以26的简便计算方法 浏览:799
吹东契奇最简单的方法 浏览:698
对肾脏有好处的食用方法 浏览:92
电脑四线程内存设置方法 浏览:508
数字电路通常用哪三种方法分析 浏览:9
实训课程的教学方法是什么 浏览:521
苯甲醇乙醚鉴别方法 浏览:78
苹果手机微信视频声音小解决方法 浏览:696
控制箱的连接方法 浏览:71
用什么简单的方法可以去痘 浏览:785
快速去除甲醛的小方法你知道几个 浏览:799
自行车架尺寸测量方法 浏览:120
石磨子的制作方法视频 浏览:148
行善修心的正确方法 浏览:401
薯仔炖鸡汤的正确方法和步骤 浏览:274