C++模板编程——完美转发与可变参函数模板
1 基础概念
首先介绍几个概念:
假设现在有A、B、C三个函数。
- 直接调用:在A函数中调用C就叫做直接调用,不拐弯抹角。
- 转发:在A函数中调用B函数,在B函数调用C函数,这就叫做转发。这种情况下,B函数就被当作了一个跳板函数。在转发的过程中,我们可能会向B函数中传递一些参数,这些参数最终是要被传递给C函数的。这些参数经过B函数中转,间接传递给了C函数。
- 完美转发:在转发的过程中,这些参数的类型信息可能会丢失一部分(比如实参的const信息、左值和右值属性),这种丢失参数信息的转发是不完美的。如果实参的类型信息可以通过B函数原封不动地转发给C函数,这种转发就叫做完美转发。
2 万能引用的缺点
template<typename T>
void func(T&& t)
{cout << "t = " << TypeGetter<decltype(t)>::name << endl;
}
对于上面这段代码,我们都知道T&&的类型是万能引用,func函数模板可以接收左值也可以接收右值,t可以绑定到左值也可以绑定到右值上。
在main函数中进行如下调用:
int main()
{int i = 0;func(i);func(10);
}
运行结果如下:

从运行结果可以看到,t的类型被正确推导了。当传入左值时,t被推导为左值引用;传入右值时t被推导为右值引用。
但是,不管t的类型时左值引用还是右值引用,t本身是一个左值。也就是说,传递的实参类型信息丢失了一些,不论传递进来的实参是左值还是右值,形参的类型都变成了左值。
3 通过std::forward恢复实参的类型信息
由上文可知,形参t的类型可能是右值引用或者左值引用,但是形参t本身是一个左值。
std::forward就是为了解决这一问题。
当形参t为左值引用时,std::forward转换回它原来的左值或右值性,经过forward变换后形参t还是左值。
当形参t为右值引用时,std::forward转换回它原来的左值或右值性,经过forward变换后形参t转换成了右值。
具体用法如下:
template<typename T>
void func(T&& t)
{std::forward<T>(t);
}
forward的返回值就恢复了t原本的右值和左值性。
4 完美转发
template<typename F, typename... T>
decltype(auto) func(F&& f, T&&... t)
{return forward<F>(f)(forward<T>(t)...);
}
这就是一个完美的跳板函数,传递给func函数的所有参数都通过forward函数恢复原来的左值和右值性,传递给f的参数类型信息没有任何丢失。
5 完美转发不完美
template<typename F, typename... T>
decltype(auto) func(F&& f, T&&... t)
{return forward<F>(f)(forward<T>(t)...);
}void temp(char*)
{
}int main()
{temp(NULL); // 可以正确运行func(temp, NULL); // 无法通过编译
}
NULL是一个宏定义,#define NULL 0,当调用func(temp, NULL)时,经过预处理的替换就变成了func(temp, 0);形参t就被推导为int&&,它无法转化为char*类型,所以就会编译失败。
解决办法就是调用时使用nullptr而不是NULL。
func(temp, nullptr);
这样就能解决该问题。
相关文章:
C++模板编程——完美转发与可变参函数模板
1 基础概念 首先介绍几个概念: 假设现在有A、B、C三个函数。 直接调用:在A函数中调用C就叫做直接调用,不拐弯抹角。转发:在A函数中调用B函数,在B函数调用C函数,这就叫做转发。这种情况下,B函数…...
CentOS服务器部署Docker+Jenkins持续集成环境
一、准备工作 一台运行 CentOS 的服务器,确保有足够的磁盘空间、内存资源,并且网络连接稳定。建议使用 CentOS 7 或更高版本,本文以 CentOS 7 为例进行讲解。 拥有服务器的 root 权限,因为后续安装软件包、配置环境等操作需要较…...
蓝桥杯单片机(十)PWM脉宽调制信号的发生与控制
模块训练: 一、PWM基本原理 1.占空比 2.脉宽周期与占空比 当PWM脉宽信号的频率确定时,脉宽周期也确定了,此时改变占空比即可。当利用PWM脉宽周期改变LED灯的亮度时,灯是低电平亮,所以将低电平占空比改成10%即可实现…...
Redis --- 使用HyperLogLog实现UV(访客量)
UV 和 PV 是网站或应用数据分析中的常用指标,用于衡量用户活跃度和页面访问量。 UV (Unique Visitor 独立访客): 指的是在一定时间内访问过网站或应用的独立用户数量。通常根据用户的 IP 地址、Cookies 或用户 ID 等来唯一标识一个用户。示例࿱…...
postgresql-COALESCE函数、NULLIF函数、NVL函数使用
COALESCE函数 COALESCE函数是返回参数中的第一个非null的值,它要求参数中至少有一个是非null的; select coalesce(1,null,2),coalesce(null,2,1),coalesce(null,null,null); NULLIF(ex1,ex2)函数 如果ex1与ex2相等则返回Null,不相等返回第一个表达式的值…...
《深度揭秘LDA:开启人工智能降维与分类优化的大门》
在当今人工智能蓬勃发展的时代,数据成为了驱动技术进步的核心要素。随着数据采集和存储技术的飞速发展,我们所面临的数据量不仅日益庞大,其维度也愈发复杂。高维数据虽然蕴含着丰富的信息,但却给机器学习算法带来了一系列严峻的挑…...
逐笔成交委托level2高频tick股票历史下载和分析:20250206
Level2逐笔成交逐笔委托数据分享下载 通过Level2的逐笔成交和逐笔委托信息,这种精确到毫秒的数据能挖掘出许多有价值的信息,如庄家动向、欺诈行为,让所有交易行为无处隐藏。这适合交易高手研究主力规律,也适合人工智能进行数据挖…...
【办公类-99-01】20250201学具PDF打印会缩小一圈——解决办法:换一个PDF阅读器
背景需求: 2024年1月13日,快要放寒假了,组长拿着我们班的打印好的一叠教案来调整。 “前面周计划下面的家园共育有调整,你自己看批注。” “还有你这个教案部分的模版有问题,太小(窄)了。考虑…...
Macos安装APOC拓展库
文章目录 说明错误提示原因分析解决方法 说明 Macos安装APOC核心库 错误提示 There is no procedure with the name apoc.generate.ba registered for this database instance. Please ensure youve spelled the procedure name correctly and that the procedure is prope…...
YUV 颜色空间的数据存储格式详解
YUV 颜色空间的数据存储格式详解 在视频处理和存储中,YUV 颜色空间是一种常用的颜色表示方法。它将颜色信息分为亮度(Luma,Y)和色度(Chroma,U 和 V)两部分,适合视频压缩和传输。YUV 数据的存储格式有多种,主要分为 Planar 格式 和 Packed 格式,并结合不同的色度二次…...
Google C++ Style / 谷歌C++开源风格
文章目录 前言1. 头文件1.1 自给自足的头文件1.2 #define 防护符1.3 导入你的依赖1.4 前向声明1.5 内联函数1.6 #include 的路径及顺序 2. 作用域2.1 命名空间2.2 内部链接2.3 非成员函数、静态成员函数和全局函数2.4 局部变量2.5 静态和全局变量2.6 thread_local 变量 3. 类3.…...
HELLOCTF反序列化靶场全解
level 2 <?php/* --- HelloCTF - 反序列化靶场 关卡 2 : 类值的传递 --- HINT:尝试将flag传递出来~# -*- coding: utf-8 -*- # Author: 探姬 # Date: 2024-07-01 20:30 # Repo: github.com/ProbiusOfficial/PHPSerialize-labs # email: adminhello-ctf.com…...
Spring Boot 自动装配机制深度解析
在 Java 开发领域,Spring Boot 以其强大的功能和便捷的开发体验受到广大开发者的青睐。其中,自动装配机制是 Spring Boot 的核心特性之一,它极大地简化了 Spring 应用的开发过程,让开发者能够专注于业务逻辑的实现。本文将深入剖析…...
echarts中x轴、y轴 类目自定义换行
在echarts中可能因为某项的名字过长想要换行展示,就可以在 axisLabel 属性中自定义换行, 如以下案例在y轴上换行展示() yAxis:[ axisLabel: { formatter: function(value) { var ret // 拼接加 \n 返回的类目项 var maxLength 6 // 每…...
禅道社区版项目管理软件部署(记录篇)
系统要求(这里推荐使用docker容器化方式)安装前的准备Docker快速安装最后通过查看地址验证是否部署成功开始界面化安装配置 禅道(ZenTao)是一款国产开源的项目管理软件,专注于敏捷开发流程,支持 Scrum 和 K…...
探索C语言简易计算器程序的实现与优化
在C语言编程学习中,实现一个简易计算器是一个常见且有趣的练习项目。它不仅能帮助我们巩固基本的语法知识,如函数、循环、分支结构,还能让我们深入理解程序设计的逻辑。接下来,我们将分析三段实现简易计算器功能的C语言代码&#…...
时间序列分析(一)——基础概念篇
一、时间序列的相关概念 定义:时间序列是按时间顺序排列的一系列观测值,通常以固定间隔(如秒、天、年)记录。而时间序列分析是一种研究按时间顺序排列的数据点的统计方法,发现趋势、季节性波动、周期性和异常等模式&a…...
Python因为网络原因安装依赖库报错
现象 在终端运行以下指令 pip install pyautogui pillow keyboard 出现报错,终端信息如下: PS D:\code\Python> pip install pyautogui pillow keyboard Collecting pyautoguiUsing cached PyAutoGUI-0.9.54.tar.gz (61 kB)Installing build depe…...
【Redis】主从模式,哨兵,集群
主从复制 单点问题: 在分布式系统中,如果某个服务器程序,只有一个节点(也就是一个物理服务器)来部署这个服务器程序的话,那么可能会出现以下问题: 1.可用性问题:如果这个机器挂了…...
DockerFile详细学习
目录 1.DockerFile介绍 2.DockerFile常用指令 3.指令详细讲解 4.实例 构建Node-Exporter 构建Alertmanager 构建Mariadb 1.DockerFile介绍 什么是 Dockerfile? Dockerfile 是一个文本文件,包含了构建 Docker 镜像的所有指令。 Dockerfile 是一…...
寒假2.5
题解 web:[网鼎杯 2020 朱雀组]phpweb 打开网址,一直在刷新,并有一段警告 翻译一下 查看源码 每隔五秒钟将会提交一次form1,index.php用post方式提交了两个参数func和p,func的值为date,p的值为Y-m-d h:i:s a 执行fu…...
Temperature、Top-P、Top-K、Frequency Penalty详解
在生成式AI(比如ChatGPT)中,Temperature、Top-P、Top-K、Frequency Penalty 这些参数用于控制文本生成的多样性、随机性和重复度,它们的作用如下: 1. Temperature(温度) 作用:控制输…...
【大数据技术】编写Python代码实现词频统计(python+hadoop+mapreduce+yarn)
编写Python代码实现词频统计(python+hadoop+mapreduce+yarn) 搭建完全分布式高可用大数据集群(VMware+CentOS+FinalShell) 搭建完全分布式高可用大数据集群(Hadoop+MapReduce+Yarn) 本机PyCharm连接CentOS虚拟机 在阅读本文前,请确保已经阅读过以上三篇文章,成功搭建了…...
中国销冠,比亚迪1月销量超30万台,出口量飙升83%
近日,比亚迪公布的 1 月销量数据成为了汽车行业热议的焦点,比亚迪凭借 300538 辆的销量成绩,进一步巩固了其在新能源汽车市场的统治力,再次稳坐中国品牌汽车市场销冠宝座。 在 1 月的销售数据中,比亚迪王朝丨海洋系列无…...
App拉新、推广
任推邦 https://www.bilibili.com/video/BV1qD2qY4E7D u客直谈 https://space.bilibili.com/1817283205...
大数据sql查询速度慢有哪些原因
1.索引问题 可能缺少索引,也有可能是索引不生效 2.连接数配置:连接数过少/连接池比较小 连接数过 3.sql本身有问题,响应比较慢,比如多表 4.缓存池大小 可能是缓存问题(命中率>99%) 5.加了锁 6. redis&a…...
2 fastAPI请求参数
1. 路径参数 (Path Parameters) 路径参数是 URL 路径的一部分,通常用于标识资源的唯一性。路径参数在 FastAPI 中通过在路由装饰器中使用大括号 {} 来定义。 获取路径参数的方式 from fastapi import FastAPIapp FastAPI()app.get("/items/{item_id}"…...
为何实现大语言模型的高效推理以及充分释放 AI 芯片的计算能力对于企业级落地应用来说,被认为具备显著的研究价值与重要意义?
🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ AI 芯片:为人工智能而生的 “大脑” AI 芯片,又称人工智能加速器或计算卡,是专为加速人工智能应用,特别是深度学习任务设计的专用集成电路(A…...
Spring容器初始化扩展点:ApplicationContextInitializer
目录 一、什么是ApplicationContextInitializer?1、核心作用2、适用场景 二、ApplicationContextInitializer的使用方式1、实现ApplicationContextInitializer接口2、注册初始化器 三、ApplicationContextInitializer的执行时机四、实际应用案例1、动态设置环境变量…...
树欲静而凤不止
我不知道为什么要求一定要在抖音上举办婚礼?觉得唯一的一个作用,财力的体现。 做到了,就见了。让我觉得就像买见面一样。 见了不合适,该当如何? 这个对于认真找对象,真的很重要吗? 分钱给平台&…...
