C++的萃取技术

2024-03-11 19:36
文章标签 c++ 技术 萃取

本文主要是介绍C++的萃取技术,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、什么是traits

在《模板类型的自动推导》中提到了c++是一门静态编译语言,不支持动态类型的获取,也就更不用说提供类似c#,Java等语言的反射机制。但是,没有类型获取的接口不代表没有这种实际的需求,那么怎么解决这种需求就得靠c++的大牛们来想办法啦。
微软的MFC通过大量的定义宏来动态的生成各种类和对象。而这种方式恰恰又不是c++大牛们觉得舒适的方法,所以他们想到了模板。
在模板中,提供了Traits(萃取)技术,什么是萃取呢?简单来说,就是能够获得目标对象的类型,并依此而实现此类型对应的功能。在当红的小众语言RUST中也有萃取这种技术,表达的相对来说更清晰明白:
traits只能由三部分组成:
functions(方法)
types(类型)
constants(常量)

这样和c++一对比,其实更容易理解萃取技术的本身。
在c++的STL中,算法和容器在设计应用上是分离的,迭代器通过利用traits(又叫做特性萃取技术)萃取技术来实现特定的功能方法,达到普适性的目的。

二、实现

在前面的文章中,提到过萃取技术的实现的一些方法,在上一篇文章中也通过模板的自动推导实现过类型的获取和识别,但是,也提到了它的一些局限性的问题,那么怎么解决这些问题呢?
基本有两种解决方式:
1、使用内部定义类型typedef::value_type
2、模板的偏特化
其实上篇提到的自动推导马虎也可以算做一种解决方案。

三、实例

1、value_type例子

template<class T>
struct RData
{typedef T value_type;T * p_;RData(T *p = 0) :p_(p) {}T& operator++()const{*p_ += *p_;return *p_;}
};template<class T>
typename T::value_type TestFunc(T t)
{return ++t;
}void VT_example()
{int *p = new int(3);RData<int> rd(p);std::cout << TestFunc(rd) << std::endl;
}
int main()
{VT_example();return 0;
}

在c++的STL库中,也经常看到类似的代码。

2、偏特化的例子

class IO
{
public:void RorW() { std::cout << "reading or writting" << std::endl; }
};template <typename T, bool isRW>
class IORW
{
public:enum { RW = isRW };void RorW(T* t){SignType<isRW>().RorW(t);}template <bool N>class SignType{};template <>class SignType<true>{public:void RorW(T* t){t->RorW();std::cout << "start reading" << std::endl;}};template <>class SignType<false>{public:void RorW(T* t){//t->RorW();std::cout << "start writting" << std::endl;}};
};void TmpPartial()
{int* pnum = nullptr;IO* pio = nullptr;IORW<int, false> io1;IORW<IO, true> io2;io1.RorW(pnum);io2.RorW(pio);
}
int main()
{TmpPartial();return 0;
}

实现萃取只是偏特化的应用的一个场景,它是模板应用中一个非常广泛的情况,另外对于全特化和显示实例化要搞明白,这里就不再赘述(前面的模板相关学习有详细的说明)。

四、总结

模板的难度,从这里就可以窥探出一些来,模板带来的优势和它显而易见的难度相比,其实更阻碍了c++的普及和推广。一般学习c++的人,建议一开始只要学习模板的初步知识即可,在把类似萃取这些技术广泛熟悉后,再根据实际场景学习,会有事半功倍的效果。

这篇关于C++的萃取技术的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window