当前位置: 首页 > wzjs >正文

dede响应式网站模板相册管理网站模板下载

dede响应式网站模板,相册管理网站模板下载,网站防红链接怎么做的,福州关键词自动排名函数模板 函数模板使用 函数模板注意事项 自动类型推导,必须推导出一致的数据类型T,才可以使用 模板必须要确定出T的数据类型,才可以使用 普通函数和函数模板的类型转化 普通函数隐式类型转化(char转int) 函数模板正常使用不会发生…

函数模板

函数模板使用

函数模板注意事项

自动类型推导,必须推导出一致的数据类型T,才可以使用

模板必须要确定出T的数据类型,才可以使用

普通函数和函数模板的类型转化

普通函数隐式类型转化(char转int)

函数模板正常使用不会发生隐式类型转化【自动推导】

函数模板隐式类型转化(char转int),需要指定类型

普通函数与函数模板调用

1. 如果函数模板和普通函数都可以实现,优先调用普通函数

普通函数实现的情况

普通函数只有声明的情况

2. 可以通过空模板参数列表来强制调用函数模板

3. 函数模板也可以发生重载

4. 如果函数模板可以产生更好的匹配,优先调用函数模板

模板局限性

不能比较构造的类

解决方法:1、运算符重载 2、模板重载

模板重载:

类模板

类模板使用

类模板和函数模板区别

1. 类模板没有自动类型推导的使用方式

2. 类模板在模板参数列表中可以有默认参数

类模板中成员函数创建时机

类模板对象做函数参数

1. 指定传入的类型 --- 直接显示对象的数据类型

2. 参数模板化 --- 将对象中的参数变为模板进行传递

3. 整个类模板化 --- 将这个对象类型 模板化进行传递

类模板与继承

指定类型

子类变类模板

类模板成员函数类外实现

类模板分文件编写

person.h文件:

#pragma once
#include <iostream>
using namespace std;template<class T1, class T2>
class Person {
public:T1 m_Name;T2 m_Age;Person(T1 name, T2 age);	//只声明void show();};

person.cpp文件:

#include "person.h"template<class T1, class T2>
Person<T1, T2>::Person(T1 name, T2 age)	//类模板的类外实现
{this->m_Name = name;this->m_Age = age;
}template<class T1, class T2>
void Person<T1, T2>::show()
{cout << this->m_Name << " " << this->m_Age << endl;
}

测试代码

void test() {Person<string,int> p("张三",2);p.show();
}

解决方式1:直接包含.cpp源文件

解决方式2:将声明和实现写到同一个文件中,并更改后缀名为.hpp,hpp是约定的名称,并不是强制

将person.h文件改为person.hpp文件【约定俗成的后缀,代表类模板】:

#pragma once
#include <iostream>
using namespace std;template<class T1, class T2>
class Person {
public:T1 m_Name;T2 m_Age;Person(T1 name, T2 age);	//只声明void show();};template<class T1, class T2>
Person<T1, T2>::Person(T1 name, T2 age)	//类模板的类外实现
{this->m_Name = name;this->m_Age = age;
}template<class T1, class T2>
void Person<T1, T2>::show()
{cout << this->m_Name << " " << this->m_Age << endl;
}

类模板与友元

全局函数类内实现 - 直接在类内声明友元即可

全局函数类外实现 - 需要提前让编译器知道全局函数的存在

类模板案例

属性设置

private:T* pAddress;		//指针指向在堆区开辟的数组起始地址int m_Capacity;		//数组容量【总体容量】int m_Size;			//数组大小【占有的数据量】

构造函数实现

根据输入的容量进行初始化

	MyArray(int capacity) {		//有参构造,根据容量进行初始化this->m_Capacity = capacity;this->m_Size = 0;this->pAddress = new T[this->m_Capacity];}

根据已有的数组进行初始化

	//拷贝【防止浅拷贝问题】//构造时拷贝【当参数被声明为 const 时,函数内部不能修改这个参数的值。有助于防止意外修改传入的数据,提高代码的安全性和可维护性。】MyArray(const MyArray& arr) {		this->m_Capacity = arr.m_Capacity;this->m_Size = arr.m_Size;//深拷贝this->pAddress = new T[arr.m_Capacity];for (int i = 0; i < arr.m_Size; i++)this->pAddress[i] = arr.pAddress[i];}

析构函数实现

	~MyArray() {		//析构函数,如果堆区不为空,清空,防止出现野指针if (this->pAddress != NULL) {delete[] this->pAddress;}}

重载运算符“=”

	//重载运算符“=”,防止出现浅拷贝MyArray& operator=(const MyArray& arr) {//如果已有数据需要先释放if (this->pAddress != NULL) {delete[] this->pAddress;this->pAddress = NULL;this->m_Capacity = 0;this->m_Size = 0;}this->m_Capacity = arr.m_Capacity;this->m_Size = arr.m_Size;//深拷贝this->pAddress = new T[arr.m_Capacity];for (int i = 0; i < arr.m_Size; i++)this->pAddress[i] = arr.pAddress[i];//返回对象本身//【this存放指向该对象的地址,*this解引用即是对象本身,MyArray&代表引用】//【最终效果就是返回对象本身的引用(引用可以理解为别名,使用引用可以访问该对象)】return *this;				}

实现访问堆区数据

添加数据

	//尾插法void Push_Back(const T& val) {//判断容量是否等于大小【是否数组已经满了】if (this->m_Capacity == this->m_Size) {return;}//未满this->pAddress[this->m_Size] = val;this->m_Size++;			//更新数组大小}

删除数据

	//尾删法void Pop_Back() {//如果数组为空if (this->m_Size == 0) {return;}//不为空this->m_Size--;			//更新数组大小}

访问数据

	//通过下标访问数组T& operator[](int index) {		//返回引用是为了防止出现arr[i] = 10的赋值情况return this->pAddress[index];}

显示记录的参数

	//返回数组容量int getCapacity() {return this->m_Capacity;}//返回数组大小int getSize() {return this->m_Size;}

MyArray.hpp总的实现

#pragma once
#include <iostream>
using namespace std;template<class T>
class MyArray {
public:MyArray(int capacity) {		//有参构造,根据容量进行初始化this->m_Capacity = capacity;this->m_Size = 0;this->pAddress = new T[this->m_Capacity];}//拷贝【防止浅拷贝问题】MyArray(const MyArray& arr) {		//构造时拷贝【当参数被声明为 const 时,函数内部不能修改这个参数的值。这有助于防止意外修改传入的数据,提高代码的安全性和可维护性。】this->m_Capacity = arr.m_Capacity;this->m_Size = arr.m_Size;//深拷贝this->pAddress = new T[arr.m_Capacity];for (int i = 0; i < arr.m_Size; i++)this->pAddress[i] = arr.pAddress[i];}//重载运算符“=”,防止出现浅拷贝MyArray& operator=(const MyArray& arr) {//如果已有数据需要先释放if (this->pAddress != NULL) {delete[] this->pAddress;this->pAddress = NULL;this->m_Capacity = 0;this->m_Size = 0;}this->m_Capacity = arr.m_Capacity;this->m_Size = arr.m_Size;//深拷贝this->pAddress = new T[arr.m_Capacity];for (int i = 0; i < arr.m_Size; i++)this->pAddress[i] = arr.pAddress[i];//返回对象本身//【this存放指向该对象的地址,*this解引用即是对象本身,MyArray&代表引用】//【最终效果就是返回对象本身的引用(引用可以理解为别名,使用引用可以访问该对象)】return *this;				}//尾插法void Push_Back(const T& val) {//判断容量是否等于大小【是否数组已经满了】if (this->m_Capacity == this->m_Size) {return;}//未满this->pAddress[this->m_Size] = val;this->m_Size++;			//更新数组大小}//尾删法void Pop_Back() {//如果数组为空if (this->m_Size == 0) {return;}//不为空this->m_Size--;			//更新数组大小}//通过下标访问数组T& operator[](int index) {		//返回引用是为了防止出现arr[i] = 10的赋值情况return this->pAddress[index];}//返回数组容量int getCapacity() {return this->m_Capacity;}//返回数组大小int getSize() {return this->m_Size;}~MyArray() {		//析构函数,如果堆区不为空,清空,防止出现野指针if (this->pAddress != NULL) {delete[] this->pAddress;}}private:T* pAddress;		//指针指向在堆区开辟的数组起始地址int m_Capacity;		//数组容量【总体容量】int m_Size;			//数组大小【占有的数据量】};

测试代码

class Person {
public:string m_Name;int m_Age;Person() {};Person(string name, int age){this->m_Name = name;this->m_Age = age;}void show(){cout << this->m_Name << " " << this->m_Age << endl;}};void test() {MyArray<int> arr1(5);//MyArray<int> arr2(arr1);//MyArray<int> arr3(100);//arr3 = arr1;for (int i = 0; i < arr1.getCapacity(); i++)arr1.Push_Back(i);cout << "=====================arr1<int>=======================" << endl;cout << "capacity: " << arr1.getCapacity() << endl;cout << "size " << arr1.getSize() << endl;for (int i = 0; i < arr1.getSize(); i++)cout << arr1[i] << endl;arr1.Pop_Back();cout << "==============arr1尾删后================" << endl;cout << "capacity: " << arr1.getCapacity() << endl;cout << "size " << arr1.getSize() << endl;for (int i = 0; i < arr1.getSize(); i++)cout << arr1[i] << endl;MyArray<char> arr2(6);for (int i = 0; i < arr2.getCapacity(); i++)arr2.Push_Back(i+97);cout << "====================arr2<char>=========================" << endl;cout << "capacity: " << arr2.getCapacity() << endl;cout << "size " << arr2.getSize() << endl;for (int i = 0; i < arr2.getSize(); i++)cout << arr2[i] << endl;MyArray<Person> arr3(3);for (int i = 0; i < arr3.getCapacity(); i++) {Person p("man"+ std::to_string(i), i);arr3.Push_Back(p);}cout << "====================arr3<Person>=========================" << endl;cout << "capacity: " << arr3.getCapacity() << endl;cout << "size " << arr3.getSize() << endl;for (int i = 0; i < arr3.getSize(); i++)arr3[i].show();}


文章转载自:

http://4kHs3Hvv.mspkz.cn
http://g9WNIDig.mspkz.cn
http://R1IFBAfJ.mspkz.cn
http://IHSufQU0.mspkz.cn
http://s7kwEvrg.mspkz.cn
http://Sa9P1QrA.mspkz.cn
http://FpXz7ypW.mspkz.cn
http://0zrfoIkc.mspkz.cn
http://84iPF4se.mspkz.cn
http://WekpxrL7.mspkz.cn
http://uRUlIqd6.mspkz.cn
http://EaaNpWMR.mspkz.cn
http://8qUrC3rq.mspkz.cn
http://bpSGcadY.mspkz.cn
http://Q2DmJvzL.mspkz.cn
http://7jspC0Zh.mspkz.cn
http://DuTEGBaq.mspkz.cn
http://tRj6k4uZ.mspkz.cn
http://kg7ESPd5.mspkz.cn
http://WIQulNGJ.mspkz.cn
http://8zHrefKd.mspkz.cn
http://No0AkX6W.mspkz.cn
http://g05mllP1.mspkz.cn
http://61W7WgZk.mspkz.cn
http://U0BO4UJl.mspkz.cn
http://t4bxhWjA.mspkz.cn
http://7Cnkh0Pl.mspkz.cn
http://zb7gVCW7.mspkz.cn
http://i1zYWUT2.mspkz.cn
http://L0B3l4z5.mspkz.cn
http://www.dtcms.com/wzjs/628697.html

相关文章:

  • 网站定制开发是什么郑州网站建设冫汉狮网络
  • 余杭住房和城乡建设局网站做网签合同的网站是
  • 摄影网站开发背景怎么写石家庄做外贸的网站
  • iis如何建立网站沈阳做网站怎样收费
  • 汽车网站方案拍拍网站源码
  • wordpress 网站地图类济南市建设执业资格注册中心网站
  • 网站定位包括哪些内容贵阳利于优化的网站
  • 长沙做php的网站建设seo搜索优化服务
  • 加强网站建设会小程
  • 胶州建设信息网站关键词代发排名
  • 网站建设计划书天津it外包公司
  • wordpress网站防护国外有什么网站做游戏吗
  • 做网站要学什么专业电子信息工程是互联网专业吗
  • 电子商务网站开发人员要求wordpress图片展示
  • 网站音乐播放器插件平面设计公司平面图
  • 用织梦做企业网站服务器租用多少钱一台
  • 查看wordpress代码淘宝客网站怎么做优化
  • 广东网站建设专业公司哪家好网站让百度收录
  • 一般网站开发语言免费logo制作
  • 门户网站 销售舟山建站
  • 网站的栏目关键词wordpress浮动音乐
  • 诗人做的网站.cc后缀网站
  • html制作音乐网站设计网页页面
  • 网站后台插件搭建网站做淘宝客
  • 网络推广招聘宁波网站排名优化费用
  • 如何学习网站开发网站的代理页面怎么做的
  • 微信的网站怎么做怎么样做网站卖东西
  • 做网站 珠海软文素材网
  • 网站制作合同范本线上营销平台有哪些
  • 西安网站建设项目如何在百度免费发布广告