判断一个类型是否有reserve方法

2024-06-23 11:52

本文主要是介绍判断一个类型是否有reserve方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用std::enable_if_t来帮助选择匹配的函数。以容器是否含有reserve方法作为示例。

1. 实现方式一

#include <iostream>
#include <vector>
#include <list>
#include <type_traits>  // std::declval/* 判断传入类型是否有reserve方法 */
template<typename ...>
using void_t = void;template <typename T, typename = void>
struct has_reserve: std::false_type {};template <typename T>
struct has_reserve<T, void_t<decltype(std::declval<T&>().reserve(1U))>> : std::true_type { };template<typename C, typename T>
std::enable_if_t<has_reserve<C>::value, void>putData(C& container, T* ptr, size_t size) {std::cout << __PRETTY_FUNCTION__ << std::endl;container.reserve(container.size() + size);for(size_t i = 0; i < size; ++i){container.push_back(ptr[i]);}
}template<typename C, typename T>
std::enable_if_t<!has_reserve<C>::value, void>putData(C& container, T* ptr, size_t size) {std::cout << __PRETTY_FUNCTION__ << std::endl;for(size_t i = 0; i < size; ++i){container.push_back(ptr[i]);}
}int main() {std::list<int> lst;std::vector<int> vec;int a[] = {1,2,3,4,5};putData(lst, a, 5);  // 调用没有reserve函数版本的putDataputData(vec, a, 5);  // 调用含有reserve函数版本的putDatafor(const auto&it: lst){std::cout << it << " ";}std::cout << std::endl;for(const auto&it: vec){std::cout << it << " ";}std::cout << std::endl;
}

输出:

std::enable_if_t<(! has_reserve<C>::value), void> putData(C&, T*, size_t) [with C = std::__cxx11::list<int>; T = int; std::enable_if_t<(! has_reserve<C>::value), void> = void; size_t = long unsigned int]
std::enable_if_t<has_reserve<C>::value, void> putData(C&, T*, size_t) [with C = std::vector<int>; T = int; std::enable_if_t<has_reserve<C>::value, void> = void; size_t = long unsigned int]
1 2 3 4 5 
1 2 3 4 5 

2. 实现方式二

#include <iostream>
#include <vector>
#include <list>
#include <type_traits>  // std::declval
#include <string>/* 判断传入类型是否有reserve方法 */
template<typename ...>
using void_t = void;template <typename T, typename = void>
struct has_reserve: std::false_type {};template <typename T>
struct has_reserve<T, void_t<decltype(std::declval<T&>().reserve(1U))>> : std::true_type {};  // 针对容器中存储的是整型数据
//struct has_reserve<T, void_t<decltype(std::declval<T&>().reserve(std::string("abc")))>> : std::true_type {};  // 针对容器中存储的是std::stringtemplate<typename C, typename T>
void _putData(C& container, T* ptr, size_t size, std::true_type) {std::cout << __PRETTY_FUNCTION__ << std::endl;container.reserve(container.size() + size);for(size_t i = 0; i < size; ++i){container.push_back(ptr[i]);}
}template<typename C, typename T>
void _putData(C& container, T* ptr, size_t size, std::false_type) {std::cout << __PRETTY_FUNCTION__ << std::endl;for(size_t i = 0; i < size; ++i){container.push_back(ptr[i]);}
}template<typename C, typename T>
void putData(C& container, T* ptr, size_t size){_putData(container, ptr, size, has_reserve<C>{});
}int main() {std::list<int> lst;std::vector<int> vec;int a[] = {1,2,3,4,5};putData(lst, a, 5);  // 调用没有reserve函数版本的putDataputData(vec, a, 5);  // 调用含有reserve函数版本的putDatafor(const auto&it: lst){std::cout << it << " ";}std::cout << std::endl;for(const auto&it: vec){std::cout << it << " ";}std::cout << std::endl;
}

输出结果:

void _putData(C&, T*, size_t, std::false_type) [with C = std::__cxx11::list<int>; T = int; size_t = long unsigned int; std::false_type = std::integral_constant<bool, false>]
void _putData(C&, T*, size_t, std::true_type) [with C = std::vector<int>; T = int; size_t = long unsigned int; std::true_type = std::integral_constant<bool, true>]
1 2 3 4 5 
1 2 3 4 5 

这篇关于判断一个类型是否有reserve方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087088

相关文章

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

poj 3259 uva 558 Wormholes(bellman最短路负权回路判断)

poj 3259: 题意:John的农场里n块地,m条路连接两块地,w个虫洞,虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts。 任务是求你会不会在从某块地出发后又回来,看到了离开之前的自己。 判断树中是否存在负权回路就ok了。 bellman代码: #include<stdio.h>const int MaxN = 501;//农场数const int

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

zoj 1721 判断2条线段(完全)相交

给出起点,终点,与一些障碍线段。 求起点到终点的最短路。 枚举2点的距离,然后最短路。 2点可达条件:没有线段与这2点所构成的线段(完全)相交。 const double eps = 1e-8 ;double add(double x , double y){if(fabs(x+y) < eps*(fabs(x) + fabs(y))) return 0 ;return x + y ;

POJ1269 判断2条直线的位置关系

题目大意:给两个点能够确定一条直线,题目给出两条直线(由4个点确定),要求判断出这两条直线的关系:平行,同线,相交。如果相交还要求出交点坐标。 解题思路: 先判断两条直线p1p2, q1q2是否共线, 如果不是,再判断 直线 是否平行, 如果还不是, 则两直线相交。  判断共线:  p1p2q1 共线 且 p1p2q2 共线 ,共线用叉乘为 0  来判断,  判断 平行:  p1p

Codeforces Round #113 (Div. 2) B 判断多边形是否在凸包内

题目点击打开链接 凸多边形A, 多边形B, 判断B是否严格在A内。  注意AB有重点 。  将A,B上的点合在一起求凸包,如果凸包上的点是B的某个点,则B肯定不在A内。 或者说B上的某点在凸包的边上则也说明B不严格在A里面。 这个处理有个巧妙的方法,只需在求凸包的时候, <=  改成< 也就是说凸包一条边上的所有点都重复点都记录在凸包里面了。 另外不能去重点。 int