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

<<C++primer>>函数模板与类模板相关知识点整理

1.类型萃取的原理

类型萃取利用模板形参的推演方式使得类型去掉了引用性质:

//消除引用,保留原始特性  //类型萃取
/// </summary>
/// <param name="it"></param>
template<class _Ty>
struct my_remove_reference
{my_remove_reference(){int x = 10;_Ty Y = 10; }
};
template<class _Ty>
struct my_remove_reference<_Ty&>
{my_remove_reference(){int x = 10;_Ty Y = 10;}
};
template<class _Ty>
struct my_remove_reference<_Ty&&>
{my_remove_reference(){int x = 10;_Ty Y = 10;}};int main()
{my_remove_reference<int>i;my_remove_reference<int&>ilr;my_remove_reference<const int&>cilr;//调用struct my_remove_reference<_Ty&>my_remove_reference<int&&>rll; //调用struct my_remove_reference<_Ty&&>//student<int&> s1;
//	cout << s1.X << endl;
}
#endif

使用示例1:acs作为了a的引用。

/*类型转化示例,头文件type_traits*/
//1 转换成引用型别
int  main()
{int a = 10;int& b = a;add_lvalue_reference<int>::type acs  = a;acs = 100;cout << a;
}

使用示例2:rm的类型是int 而非int&

2 将引用转化为值类型
int main()
{int a = 10;int& ab = a;remove_reference<int&>::type rm = ab;std::cout<<typeid(rm).name();return 0;
}

2.在模板函数中,编译器无法确认返回类型,需要使用typename 告知其是类型

使用类的类型成员:为了知道模板函数中名字是否可以表示一个类型,用typename通知这是表示一个类型。

#if 0
/*使用类的类型成员:为了知道模板函数中名字是否可以表示一个类型,用typename通知这是表示一个类型*/
//此为返回一个容器成员类型的函数
template<class T>
typename T::value_type fun(const T& x)
{cout << "T" << typeid(T).name() << "\n";cout <<"typeid(T::value_type).name()"<< typeid(T::value_type).name() << "\n";if (!x.empty()){return x.back();}else {return typename T::value_type();}//std::cout << x << " ,   T::value_type :" << typeid(T).name() << "\n";//return typename T:: value_type();
}int main()
{int a = 10;vector<int> vec;auto res1 = fun<vector<int>>(vec);cout << typeid(res1).name() << "\n";cout << res1;return 0;
}
#endif

T::value_type  表示为容器元素的类型。

注意:auto res1 = fun<vector<int>>(vec); 也可写成auto res1 = fun(vec);

一个是显示指定参数类型,一个是隐式的自动匹配对应的模板函数。

3.使用decltype关键字返回你想要返回的类型 

在某些时候我们不想使用指定模板实参作为函数的返回值,而使用此关键字告诉编译器,返回类型和decltype括号中的类型相同。

示例:

template<class It>
auto fnc1(It beg, It end) ->decltype(*beg)
{return *beg;
}int main()
{string st = "111";vector<string>arr={ "111" };auto &res = fnc1(arr.begin(), arr.end());cout << typeid(res).name() << " ";cout << res;return 0;
}

移除引用型别

template<class It>
auto fnc(It beg, It end) ->//decltype(*beg)
typename remove_reference<decltype(*beg)> ::type
{cout<<typeid(*beg).name()<<"             ";//*beg = 100;return *beg;
}int main()
{string st = "111";vector<string>arr={ "111" };auto res = fnc(arr.begin(), arr.end());cout << typeid(res).name() << " ";cout << res;return 0;
}

注意,此函数调用时的返回类型要求是非引用类型,所以在函数中做了移除引用型别的处理。

4.引用折叠和理解move

5.模板参数与作用域

6.类模板的成员模板

7,显示实例化

http://www.lryc.cn/news/228861.html

相关文章:

  • 一小时学习 Git 笔记
  • 简单漂亮的登录页面
  • Leetcode-145 二叉树的后序遍历
  • 详解JDBC
  • 江门車馬炮汽车金融中心 11月11日开张
  • Arthas设置参数以Json形式输出
  • 优雅关闭TCP的函数shutdown效果展示
  • 商品管理幻灯图片更换实现
  • tomcat下载与使用教程
  • 通过 Elasticsearch 和 Go 使用混合搜索进行地鼠狩猎
  • 【LIUNX】配置缓存DNS服务
  • Arduino驱动A01NYUB防水超声波传感器(超声波传感器)
  • curl(八)时间和环境变量以及配置
  • K8S知识点(十)
  • Netty实现通信框架
  • 【OpenCV实现图像:用OpenCV图像处理技巧之白平衡算法】
  • 文件包含 [ZJCTF 2019]NiZhuanSiWei1
  • Java网络编程基础内容
  • DevChat:开发者专属的基于IDE插件化编程协助工具
  • Python数据容器之[列表]
  • 大咖直播间”系列直播课第一期——如何抓住HarmonyOS带来的机遇?
  • 跨域:利用JSONP、WebSocket实现跨域访问
  • java项目之戒烟网站(ssm+vue)
  • Redis集群,你真的学会了吗?
  • 手机地磁传感器与常见问题
  • EF Core 数据库映射成实体类
  • 【算法优选】 动态规划之斐波那契数列模型
  • FreeRTOS知识梳理
  • 冒泡排序算法(C++版)
  • 第22章_数据库的设计规范