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

C++ 模板与泛型编程入门

C 模板与泛型编程入门模板把类型及非类型参数作为参数在编译期由编译器按用法生成具体函数或类是 C泛型编程与STL的基础。下文以Max、简单类模板、选择排序及可定制比较器为例说明常见写法排序复杂度为 (O(n^2))仅作模板演示工程中应使用std::sort等标准算法。目录从重复实现到函数模板模板实例化在编译期如何发生函数模板与类模板对照类模板与标准库的关系示例函数模板选择排序选择排序过程示意传入比较逻辑可调用对象小结参考链接从重复实现到函数模板若仅为不同类型各写一份「逻辑相同、仅类型不同」的函数维护成本高intmax_int(intx,inty){returnxy?x:y;}doublemax_double(doublea,doubleb){returnab?a:b;}函数模板将类型抽象为参数由调用处推导或显式指定templatetypenameTTmax_value(constTx,constTy){returnxy?x:y;}template typename T写成template class T等价引入类型形参T。调用max_value(1, 2)时通常推导出T为int编译器生成对应实例称为模板实例化。若实参类型不一致且无法统一推导需显式指定max_valuedouble(1, 2.0)等或调整设计如双类型形参。双类型形参示例两实参类型可不同templatetypenameT,typenameUautomax_mixed(constTa,constUb)-decltype(ab?b:a){returnab?b:a;}C14 起可写auto返回类型C20 起常用std::common_type_t或auto配合约束简化。模板实例化在编译期如何发生产物编译期源代码函数模板 max_value 定义调用 max_value 含 int 实参推导 T 为 int生成具体函数实例目标文件中的机器码模板默认在用到时实例化显式实例化template int max_valueint(const int, const int);可将定义固定到特定翻译单元用于控制编译时间或隐藏实现需配合设计。函数模板与类模板对照项目函数模板类模板引入方式template typename T R f(...)template typename T class C { ... };使用形态多数场景由实参推导T一般显式写Cint少数可 CTADC17典型用途算法、工具函数容器、资源管理、策略类关键字typename与class在类型形参上等价同左类模板容器、智能指针等常以类模板出现在类名后给出模板实参得到具体类型templatetypenameTclassBox{T content_{};public:voidset(constTv){content_v;}constTget()const{returncontent_;}};// Boxint、Boxstd::string 等为不同类类型std::vectorint、std::mapstd::string, int等同理。与标准库的关系STL容器多为类模板算法多为函数模板如std::sort、std::find通过迭代器与类型推导在不同容器上复用同一套算法接口。日常开发应优先使用标准库自定义模板多用于领域抽象或与库组合。容器类模板vectorlistmap迭代器区间begin 与 end算法函数模板sort / find / copy ...层次角色容器分配存储、提供begin()/end()迭代器抽象「位置」使算法与具体容器解耦算法只依赖迭代器类别能力随机访问、前向等示例函数模板选择排序以下用选择排序展示「同一套逻辑适用于多种T」要求T支持或通过下文方式定制比较。#includeiostream#includestringtemplatetypenameTboolless_than(constTa,constTb){returnab;}templatetypenameTvoidselection_sort(T*arr,intn){for(inti0;in-1;i){intmin_indexi;for(intji1;jn;j){if(less_than(arr[j],arr[min_index]))min_indexj;}if(min_index!i){T tmparr[i];arr[i]arr[min_index];arr[min_index]tmp;}}}templatetypenameTvoidprint_array(constT*arr,intn){for(inti0;in;i)std::coutarr[i](i1n? :\n);}int/double/std::string等已定义operator的类型可直接使用。数组长度在 C 中更惯用迭代器区间或std::spanC20此处沿用「指针 长度」便于与原文示例对照。选择排序过程示意每一轮在未排序后缀[i, n)中选最小元与位置i交换共约 (n-1) 轮。初始: [ 64, 25, 12, 22, 11 ] i0 选最小 11: [ 11, 25, 12, 22, 64 ] i1 选最小 12: [ 11, 12, 25, 22, 64 ] i2 选最小 22: [ 11, 12, 22, 25, 64 ] i3 选最小 25: [ 11, 12, 22, 25, 64 ] → 已有序第 i 轮在 arr[i..n-1] 中找最小下标 min_indexswap(arr[i], arr[min_index])i 从 0 递增到 n-2传入比较逻辑可调用对象若需按其它规则排序如按字符串长度可将比较操作做成可调用对象函数指针、函数对象、lambda并由模板形参Compare接收与std::sort(begin, end, comp)的思路一致#includeiostream#includestringstructStudent{std::string name;intscore{};};boolshorter_name_first(constStudenta,constStudentb){returna.name.size()b.name.size();}templatetypenameT,typenameComparevoidselection_sort_cmp(T*arr,intn,Compare comp){for(inti0;in-1;i){intmin_indexi;for(intji1;jn;j){if(comp(arr[j],arr[min_index]))min_indexj;}if(min_index!i){T tmparr[i];arr[i]arr[min_index];arr[min_index]tmp;}}}调用示例Student s[]{{Alice,90},{Bob,85},{Charlie,95},{David,88}};selection_sort_cmp(s,4,shorter_name_first);Compare常由编译器从实参推导亦可传入lambda无需单独命名比较函数。selection_sort_cmp(s,4,[](constStudenta,constStudentb){returna.scoreb.score;// 按分数降序});selection_sort_cmp调用端推导为 Comparelambda / 函数指针 / 函数对象模板形参 Comparecomp(a,b) 判定先后小结点说明复用一份模板定义多类型实例化减少重复逻辑类型检查实例化阶段检查能否调用comp、operator等优于盲目void*性能实例化后与普通函数类似抽象不必然带来运行时虚调用的开销工程实践复杂需求优先组合STL、概念C20 constraints、constexpr等现代特性学习用排序请用std::sort/std::ranges::sortC20 概念简述在包含concepts的前提下可用template std::totally_ordered T或requires约束T必须具备的操作错误信息更早、更清晰语义上仍属模板机制扩展。机制作用requires子句限定可实例化的类型集合concept命名一组约束便于复用if constexpr编译期分支避免对不可用分支实例化参考链接相关主题公开文章背景阅读https://mp.weixin.qq.com/s/zTHvLUVT0qSjFIyMsdhrhQ模板基础Templates - cppreference.com语法与实例化规则以当前采用的C 标准版本为准。

相关文章:

C++ 模板与泛型编程入门

C 模板与泛型编程入门 模板把类型(及非类型参数)作为参数,在编译期由编译器按用法生成具体函数或类,是 C 泛型编程与 STL 的基础。下文以 Max、简单类模板、选择排序及可定制比较器为例说明常见写法;排序复杂度为 (O(…...

3个核心价值:bilibili-api的API开发与数据接口应用

3个核心价值:bilibili-api的API开发与数据接口应用 【免费下载链接】bilibili-api B站API收集整理及开发,不再维护 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-api 作为开发者,我们经常需要获取B站丰富的视频、用户及互动…...

MyBatis 中 CDATA 的实战应用与避坑指南

1. 为什么MyBatis需要CDATA 在MyBatis的日常开发中&#xff0c;我们经常需要在XML映射文件中编写SQL语句。但XML本身对特殊字符有着严格的限制&#xff0c;比如小于号(<)、大于号(>)、和号(&)等字符在XML中都有特殊含义。这就导致了一个很现实的问题&#xff1a;当我…...

告别硬编码!用BAdI LE_SHP_TAB_CUST_ITEM给VL01N交货单加个自定义标签页(附完整代码)

告别硬编码&#xff01;用BAdI LE_SHP_TAB_CUST_ITEM实现交货单标签页优雅增强 在SAP SD模块的日常开发中&#xff0c;为外向交货单添加客户化信息是再常见不过的需求。但很多开发者习惯直接在标准程序里插入硬编码&#xff0c;这种看似快捷的方式往往会给后续维护埋下隐患。今…...

Delphi XE在Linux上开发桌面应用:从安装FMXLinux插件到第一个跨平台GUI程序

Delphi XE在Linux上开发桌面应用&#xff1a;从安装FMXLinux插件到第一个跨平台GUI程序 引言 对于熟悉Delphi的开发者来说&#xff0c;将Windows平台上的成熟应用迁移到Linux环境一直是个挑战。Delphi XE虽然支持Linux开发&#xff0c;但官方仅提供命令行应用的支持&#xff…...

Mysql是怎么加锁的?

原文地址https://www.xiaolincoding.com/mysql/lock/how_to_lock.html#%E4%BB%80%E4%B9%88-sql-%E8%AF%AD%E5%8F%A5%E4%BC%9A%E5%8A%A0%E8%A1%8C%E7%BA%A7%E9%94%81 我只是精简一下做个记录 这篇汇总将基于 MySQL 8.0 的 InnoDB 引擎&#xff0c;在 可重复读&#xff08;Repe…...

LeetCode 153. 旋转排序数组找最小值:二分最优思路

LeetCode中等难度的经典题目——153. 寻找旋转排序数组中的最小值。这道题的核心考点是「二分查找」&#xff0c;难点在于如何利用“旋转排序数组”的特性&#xff0c;在O(log n)时间复杂度内找到最小值&#xff0c;也是面试中常考的二分变形题。 一、题目解读&#xff1a;读懂…...

uniapp中如何用lottie-miniprogram加载json动画?5分钟搞定炫酷效果

Uniapp中5分钟集成Lottie动画&#xff1a;从原理到实战的完整指南 在移动应用开发中&#xff0c;精美的动画效果往往能显著提升用户体验。对于Uniapp开发者来说&#xff0c;Lottie-miniprogram提供了一种高效的方式&#xff0c;可以直接加载设计师导出的JSON动画文件&#xff0…...

win11 WSL ubuntu24.04 安装两个、重命名

导出&#xff1a; wsl --export Ubuntu-24.04 D:\Ubuntu-24.04.tar导入新镜像&#xff1a; wsl --import Ubuntu-24.04-2 D:\Ubuntu-24.04-2\Ubuntu-24.04-2 D:\Ubuntu-24.04.tar...

手把手教你用RTABMAP+T265在Windows10上实现室内三维扫描(含标定技巧)

手把手教你用RTABMAPT265在Windows10上实现高精度室内三维扫描 第一次接触室内三维扫描时&#xff0c;我被这项技术深深吸引——它能让物理空间瞬间数字化&#xff0c;就像给现实世界按下"CtrlC"。但真正动手配置RTABMAP和T265相机时&#xff0c;才发现这条路并不平坦…...

OpenClaw多模型切换指南:Qwen3-32B与本地Llama混合调用

OpenClaw多模型切换指南&#xff1a;Qwen3-32B与本地Llama混合调用 1. 为什么需要多模型切换&#xff1f; 去年冬天&#xff0c;当我第一次尝试用OpenClaw自动处理周报时&#xff0c;发现一个有趣的现象&#xff1a;用同一个模型处理文本润色和代码生成任务&#xff0c;效果差…...

MAX17332 Arduino库详解:单节锂电池燃料计量与独立充电控制

1. 项目概述 MAX17332 是 Maxim Integrated&#xff08;现为 Analog Devices&#xff09;推出的一款高度集成的单节锂离子/锂聚合物电池管理芯片&#xff0c;专为紧凑型便携设备设计。它并非传统意义上的“纯BMS”&#xff08;Battery Management System&#xff09;&#xff0…...

计算机毕业设计:基于Django与LSTM的大众点评评价预测系统 Django框架 LSTM Hadoop Spark Hive 可视化 大数据 食品 食物(建议收藏)✅

博主介绍&#xff1a;✌全网粉丝10W&#xff0c;前互联网大厂软件研发、集结硕博英豪成立软件开发工作室&#xff0c;专注于计算机相关专业项目实战6年之久&#xff0c;累计开发项目作品上万套。凭借丰富的经验与专业实力&#xff0c;已帮助成千上万的学生顺利毕业&#xff0c;…...

BlueROV2进阶:巧用ArduSub参数配置实现多舵机协同控制

1. 从单舵机到多舵机协同的跨越 第一次用Pixhawk控制单个舵机转动时的兴奋感还记忆犹新&#xff0c;但当真正开始构建BlueROV2这样的水下机器人时&#xff0c;你会发现单一舵机控制远远不够。想象一下这样的场景&#xff1a;机械爪需要精准开合&#xff0c;云台要平稳转动&…...

告别论文 ddl 焦虑!PaperZZ AI:本科毕业论文从 0 到 1 的极速生成攻略[特殊字符]

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿/期刊论文paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertation 还在为本科毕业论文熬大夜&#xff1f;选题没思路、文献找不到、大纲搭不起来、初稿写不出…… 无数…...

FastAPI流式AI接口设计陷阱大全(2024高频真题+源码级调试实录)

第一章&#xff1a;FastAPI流式AI接口设计陷阱大全&#xff08;2024高频真题源码级调试实录&#xff09;流式响应被中间件静默截断 FastAPI 默认启用的 Starlette 中间件&#xff08;如 HTTPSRedirectMiddleware 或自定义日志中间件&#xff09;可能在未显式处理 StreamingResp…...

【FastAPI 2.0流式AI响应核心机密】:3大异步协程调度陷阱、2处EventSource底层劫持点、1个未公开的StreamingResponse状态机设计缺陷

第一章&#xff1a;FastAPI 2.0流式AI响应的架构演进与设计哲学FastAPI 2.0 将流式响应能力从实验性支持提升为核心原语&#xff0c;其底层重构了 Starlette 的响应生命周期与事件循环集成机制&#xff0c;使 Server-Sent Events&#xff08;SSE&#xff09;、text/event-strea…...

遥感影像配准总对不齐?OpenCV+RST+PROJ4三重坐标系对齐实战(附WGS84→UTM→影像本地坐标的转换矩阵速查表)

第一章&#xff1a;Shell脚本的基本语法和命令Shell脚本是Linux/Unix系统自动化任务的核心工具&#xff0c;以可执行文本文件形式存在&#xff0c;由Bash等shell解释器逐行解析运行。其语法简洁但严谨&#xff0c;对空格、分号、引号和换行符敏感&#xff0c;需严格遵循语法规则…...

OpenClaw隐私方案:nanobot镜像本地化部署与敏感数据处理实践

OpenClaw隐私方案&#xff1a;nanobot镜像本地化部署与敏感数据处理实践 1. 为什么需要本地化部署的AI助手&#xff1f; 去年在处理一份涉及客户隐私的法律文件时&#xff0c;我遇到了一个两难选择&#xff1a;要么手动逐条整理数百页文档&#xff0c;要么使用云端AI工具但面…...

开源 AI 应用平台实战部署:从零搭建到插件调试避坑指南

1. 开源AI平台部署前的环境准备 在开始部署Dify和AIFlowy之前&#xff0c;环境准备是至关重要的一步。我遇到过不少开发者因为基础环境没配好&#xff0c;导致后续步骤频繁报错的情况。这里分享下Windows和Linux双平台下的实战经验。 对于Dify平台&#xff0c;你需要准备Python…...

智能家居控制中心:OpenClaw+Qwen3.5-9B语音指令中转

智能家居控制中心&#xff1a;OpenClawQwen3.5-9B语音指令中转 1. 为什么需要语音控制的智能家居中枢&#xff1f; 去年装修新房时&#xff0c;我装了十几款不同品牌的智能设备——从米家的灯泡到涂鸦的窗帘电机&#xff0c;再到HomeKit的温控器。每次想调整家居状态&#xf…...

从安装到跑通第一个旋转立方体:Ubuntu 22.04 + OpenGL完整开发环境搭建实录

从零到旋转立方体&#xff1a;Ubuntu 22.04下OpenGL开发环境实战指南 刚接触图形编程时&#xff0c;最令人兴奋的莫过于看到自己编写的代码在屏幕上"活"起来。本文将带你从零开始&#xff0c;在Ubuntu 22.04系统上搭建完整的OpenGL开发环境&#xff0c;并最终实现一个…...

OpenClaw负载测试:GLM-4.7-Flash并发处理能力评估

OpenClaw负载测试&#xff1a;GLM-4.7-Flash并发处理能力评估 1. 测试背景与目标 上周在尝试用OpenClaw自动化处理一批市场调研报告时&#xff0c;遇到了一个典型问题&#xff1a;当我同时提交20份PDF文件让AI助手提取关键数据时&#xff0c;系统开始出现响应延迟和部分任务超…...

MySQL 事务机制深度解析:从 ACID 到底层实现

MySQL 事务机制深度解析&#xff1a;从 ACID 到底层实现 MySQL 的事务机制主要由 InnoDB 存储引擎 实现&#xff0c;核心围绕 ACID 四大特性&#xff0c;通过 日志系统&#xff08;redo log、undo log&#xff09;、锁机制 和 MVCC&#xff08;多版本并发控制&#xff09; 共同…...

RRT*在ROS中的实战:用Gazebo仿真实现动态避障(Python+ROS Noetic)

RRT*在ROS中的实战&#xff1a;用Gazebo仿真实现动态避障&#xff08;PythonROS Noetic&#xff09; 路径规划是机器人自主导航的核心技术之一。在复杂动态环境中&#xff0c;如何快速找到一条安全且优化的路径一直是研究热点。RRT*&#xff08;Rapidly-exploring Random Trees…...

小型电商自动化:OpenClaw+nanobot处理订单邮件

小型电商自动化&#xff1a;OpenClawnanobot处理订单邮件 1. 为什么选择OpenClaw处理电商订单 作为一个经营小型电商的个体商户&#xff0c;我每天要处理几十封来自Gmail的订单邮件。这些邮件包含客户信息、商品清单和收货地址&#xff0c;需要手动录入到库存表格、生成物流单…...

ncmdumpGUI:突破网易云音乐NCM格式限制的高效解决方案

ncmdumpGUI&#xff1a;突破网易云音乐NCM格式限制的高效解决方案 【免费下载链接】ncmdumpGUI C#版本网易云音乐ncm文件格式转换&#xff0c;Windows图形界面版本 项目地址: https://gitcode.com/gh_mirrors/nc/ncmdumpGUI ncmdumpGUI是一款开源的音频格式转换工具&am…...

单片机开发三大软件架构对比与实践

单片机开发常用软件架构深度解析1. 项目概述在嵌入式系统开发中&#xff0c;软件架构设计直接影响系统的可靠性、可维护性和实时性。本文系统分析三种主流单片机软件架构方案&#xff0c;包括时间片轮询法、操作系统方案和前后台顺序执行法&#xff0c;为开发者提供架构选型参考…...

el-tabs报错Cannot read properties of null (reading ‘insertBefore‘)

使用elementui-plus的tabs组件在开发中遇到的一个问题&#xff0c;分析了代码&#xff0c;发现逻辑没有任何问题&#xff0c;但是点击tab切换就会报错&#xff1a;Uncaught (in promise) TypeError: Cannot read properties of null (reading insertBefore)调试发现parent参数是…...

【Python时序预测实战】基于贝叶斯优化的Transformer单变量时序预测模型构建与调优

1. 为什么选择Transformer做时序预测&#xff1f; 我第一次用Transformer做销量预测时&#xff0c;心里其实挺没底的。毕竟这玩意儿原本是搞自然语言处理的&#xff0c;就像拿菜刀削苹果——工具不太对口。但当我看到预测结果比传统LSTM提升了23%的准确率时&#xff0c;立刻真香…...