002 模板实参推断、重载与模板

模板实参推断

一、模板函数显示实参

情况1:

template <typename T1, typename T2, typename T3>
T1 sum(T2 a, T3 b)
{return a + b;
}

分析:调用的时候就需要指定T1的类型,如:sum<float>(1, 2); 于是sum函数的返回类型为float。

 

 情况2:

template <typename T1, typename T2, typename T3> //糟糕的设计,用户必须指定所有的三个模板参数
T3 sum(T1 a, T2 b) 
{return a + b;
}

分析:对于sum<float>(1, 2); 现在这个调用里指定T1类型为float,但是实际传进来的是1(int类型),会进行隐式类型转换,将1转换为float. T2的类型也可以根据sum(1,2)调用的第二个实参推断出来,这里是可能会是int. 那么T3是什么类型呢?显然这里编译器无法推断T3的类型,需要在调用时指定才能推断:

1.   sum<int, int, int>(1, 2); 这样T3就推断出来是int。 

2. 在指定显示模板实参时指定的类型是和模板参数匹配的,顺序是一一对应的,如:

    •  使用 sum<int>(1, 2); 对上面的第一个模板进行调用,那么T1对应int,T2T3则通过推断得出。

    •  使用 sum<int>(1, 2); 对上面的第二个模板进行调用,那么T1对应的类型是int,T2可以根据实际穿进去的参数进行推断,这里2为int,那么T2类型就是int,那么编译器就无法知道T3的实际类型了。

 

 二、完美转发

template<class T>
void wrapper(T&& arg) 
{// arg 始终是左值foo(std::forward<T>(arg)); // 转发为左值或右值,依赖于 T
}  分析:1. 若对 wrapper() 的调用传递右值string ,则推导 T 为 std::string(非string& 或string&& ,且 std::forward 确保将右值引用传递给 foo.2. 若对 wrapper() 的调用传递 const 左值string ,则推导 T 为 const string& ,且 std::forward 确保将 const 左值引用传递给 foo.3. 若对 wrapper() 的调用传递非 const 左值string ,则推导 T 为string& ,且 std::forward 确保将非 const 左值引用传递给 foo. 

分析:

1. 若对 wrapper() 的调用传递右值string ,则推导 T 为 std::string(非string& 或string&& ,且 std::forward 确保将右值引用传递给 foo.

2. 若对 wrapper() 的调用传递 const 左值string ,则推导 T 为 const string& ,且 std::forward 确保将 const 左值引用传递给 foo.

3. 若对 wrapper() 的调用传递非 const 左值string ,则推导 T 为string& ,且 std::forward 确保将非 const 左值引用传递给 foo.

 举例

 1 #include<iostream>
 2 #include<utility>
 3 using namespace std;
 4 
 5 void g(int &&i, int &j)
 6 {
 7     cout << i << " " << j << endl;
 8 }
 9 
10 void f(int v1, int &v2)
11 {
12     cout << v1 << " " << ++v2 << endl;
13 }
14 
15 //flip1实现不完整:顶层const和引用都丢掉了
16 template <typename F, typename T1, typename T2>
17 void flip1(F f, T1 t1, T2 t2)   
18 {
19     f(t2, t1);
20 }
21 
22 template <typename F, typename T1, typename T2>
23 void flip2(F f, T1 &&t1, T2 &&t2)
24 {
25     f(t2, t1);
26 }
27 
28 template <typename F, typename T1, typename T2>
29 void flip(F f, T1 &&t1, T2 &&t2)
30 {
31     f(std::forward<T2>(t2), std::forward<T1>(t1));
32 }
33 
34 int main()
35 {
36     int i = 0, j = 0, k = 0, l = 0;
37     cout << i << " " << j << " " << k << " " << l << endl;
38     f(42, i);         //f改变其实参i
39     flip1(f, j, 42);  //通过flip1调用f不会改变j
40     flip2(f, k, 42);  //正确:k被改变了
41     g(42, i);
42     flip(g, i, 42);   //正确:第三个参数的右值属性被保留了
43     cout << i << j << " " << k << " " << l << endl;
44     return 0;
45 }

 

重载与模板

转载于:https://www.cnblogs.com/sunbines/p/9375847.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/251112.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DOM-4 【utils/待讲评】节点创建删除、元素属性设置获取、节点属性

讲评 节点创建 Document.prototype ← document.createElement(div)document.createTextNode(xxx) // 创建文本节点document.createComment(xxx) // 创建注释节点 增加/剪切子节点 Node.prototype ← node.appendChild(node)总是在父元素的最后增加&#xff08;类似push&am…

javascript --- 事件对象和事件类型

// 无论程序使用"DOM0级"规范还是"DOM2级"规范,都会在局部产生一个event对象, // 将其打印出来研究: <div id"divBtn"><button id"rawBtn" >Click Me!</button></div> <script>const divBtn document…

关于APP更新,两包共存的解决方案

大多数是由于包名不一致导致的&#xff0c;一定要注意包名一致、不然手机会认为是两个app&#xff0c;导致两个包共存 查看包名的方法 1、hbuilder打包时会有提示 2、手机打开设置->应用->正在运行->对应app即可查看 转载于:https://www.cnblogs.com/zz-0128/p/827969…

DOM-5【兼容】滚动距离与高度、兼容模式、可视尺寸

查看滚动条的距离 方法版本window.pageXOffset / pageYOffsetIE9/IE8及以下不支持(常规)document.body.scrollLeft/scrollTopIE9/IE8及以下(部分支持&#xff0c;具体看模式)document.documentElement.scrollLeft/scrollTopIE9/IE8及以下(部分支持&#xff0c;具体看模式)wind…

python中with及closing

推荐使用 "with"语句 以管理文件:with open("hello.txt") as hello_file: for line in hello_file: print line对于不支持使用"with"语句的类似文件的对象,使用 contextlib.closing():import contextlibwith contextlib.closing(urlli…

http --- Web页面请求的历程(如何根据URL寻找到需要的资源)

HTTP概况: // 超文本传输协议(HyperText Transfer Protocol,HTTP):是Web的应用层协议,它是Web的核心. // 客户端和服务器运行在不同的端系统中,通过交换HTTP报文进行会话 // HTTP定义了这些报文的结构以及客户和服务器进行报文交换的方式 // HTTP定义了Web客户向Web服务器请求…

DOM-6 【兼容】读写样式属性、操作伪元素、运动元素初探

规范 <style type"text/css"></style><script type"text/javascript"></script>读写样式属性 .style是访问不到css样式表的&#xff0c;只能访问到行内/内联的属性&#xff0c;当未设置行内属性时&#xff0c;结果为空字符串 设…

RGBD论文阅读笔记

Single-Image Depth Perception in the Wild 简要记载一下对于利用RGB图像depth图像得到segmentation的论文。 论文名称&#xff1a;Cascaded Feature Network for Semantic Segmentation of RGB-D Images 论文出处 ICCV 2017 Lin 模型结构 数据集 NYUDv2 SUN-RGBD 性能分析 总…

vue组件调用(全局调用和局部调用)

当用vue-cli创建一个项目后, 创建项目的方法: https://www.cnblogs.com/fps2tao/p/9376847.html 编写了组件怎么,在其他组件中调用了? 组件listBox: 路径 src/components/listBox.vue <template><div class"listBox">listBox222</div> </templ…

http --- 路由器缓存与常见的状态码

路由器的缓存: // 当下路由器其主要系统性能指吞吐率、利用率、丢包率、延迟、缓存大小和实现复杂性等. // 当链路上发生拥塞时能够对新进入的数据包进行缓存 // 从而降低丢包率、维持高的链路利用率 // 用于存放路由表的内存,速度快,价格也高状态码: // 为客户端提供了一种理…

DOM-7 【兼容】事件处理函数、冒泡捕获、阻止冒泡默认事件

事件处理函数 绑定事件 绑定事件的处理函数&#xff08;事件本身是存在的&#xff0c;绑定的是相应的反馈&#xff09;事件 事件的反馈 前端交互 &#xff08;前端核心&#xff09; 绑定事件的方式 1. 句柄绑定 默认&#xff08;只能&#xff09;是事件冒泡这种事件流为…

javascript --- XHR(XMLHttpRequet)对象

XHR: // XHR(XMLHttpRequest):为向服务器发送请求和解析服务器响应提供了流畅的接口 // 能够以异步方式从服务器取得更多信息,意味着用户点击后,可以不必刷新页面也能取得新数据 // 换句话说,可以使用XHR对象获取新数据,然后再通过DOM将新数据插入到页面中.XMLHttpRequest对象…

DOM-8 【兼容】冒泡捕获流、事件与事件源对象、事件委托

事件流 1. 含义 描述从页面中接收事件的顺序 2. 分类 IE提出的 事件冒泡流 Event BubblingNetscape提出的 事件捕获流 Event Capturing 3. 阶段 事件捕获阶段 处于目标阶段 事件冒泡阶段 事件捕获先于事件冒泡执行 dom dom0&#xff1a;定义句柄方式&#xff0c;兼…

IIS6.0,Apache低版本,PHP CGI 解析漏洞

IIS6.0解析漏洞 在IIS6.0下存在这样的文件“名字.asp;名字.jpg” 代表了jpg文件可以以asp脚本类型的文件执行。 根据这个解析漏洞我们可以上传这种名字类型的图片&#xff0c;比如 1.asp;xxx.jpg 他会忽略;后边的内容&#xff0c;所以文件相当于1.asp asp一句话木马 <%eval …

UVA 3485 Bridge

题目大意 你的任务是修建一座大桥。桥上等距地摆放着若干个塔&#xff0c;塔高为H&#xff0c;宽度忽略不计。相邻两座塔之间的距离不能超过D。塔之间的绳索形成全等的对称抛物线。桥长度为B&#xff0c;绳索总长为L&#xff0c;如下图所示求建最少的塔时绳索的最下端离地的高度…

javascript --- XMLHttp2级、CORS(跨域资源共享)

FormData: // 为序列化表单以及创建与表单格式相同的数据提供了便利 var data new FromData(); data.append("name", "Nicholas");// 使用FormData标准化数据后,发送到服务器 var xhr createXHR(); xhr.onreadystatechange function () {if ( xhr.read…

ES5-拓展 this指向的总结

每个函数在执行时都有自己的this指向 1. 默认绑定规则&#xff1a; 全局中&#xff0c;this指向window this window函数的独立调用&#xff0c;this默认指向window &#xff08;不要把独立调用理解成window调用&#xff09; // 函数在全局中调用&#xff0c;也就是被window调…

Applet

Applets用于为Web应用程序提供交互功能&#xff0c;这些功能无法单独由HTML提供。它们可以捕获鼠标输入&#xff0c;并且还具有按钮或复选框等控件。响应于用户动作&#xff0c;小应用程序可以改变提供的图形内容。这使得小程序非常适合演示&#xff0c;可视化和教学。 一个app…

国内初创企业选择云计算服务器价格对比

假设我们是一家初创企业&#xff0c;现在要选择第一台服务器。业务还未确定&#xff0c;只知道是互联网业务 要求&#xff1a; 至少2核&#xff0c;否则多线程的软件都跑不了至少4G内存&#xff0c;这样可以运行数据库或者elasticsearch这种比较吃内存的东西。或者说&#xff0…

javascript --- 几个其他的跨域技术(图像Ping、JSONP、Comet)

在CORS(Cross-Origin Resource Sharing,跨域资源共享)出现以前,要实现跨域Ajax通信是很难的. 可以利用DOM中能够执行跨域请求的功能,来实现跨域通信: 浏览器到服务器的单向通信: 此项技术称为图像Ping,利用的是img.src的跨域事件 img.src只能通过侦听load和error事件来确定浏览…