类型萃取类型检查 Type-Traits LibraryType Checks --- C++20

类型萃取:类型检查 Type-Traits Library:Type Checks — C++20

Type-Traits libraryC++11的时候就已经发布,但依然随着C++版本在不断更新

类型检查 Type Checks

每种类型就是十四种主要类型之一

主要类型

template <class T> struct is_void;
template <class T> struct is_integral;
template <class T> struct is_floating_point;
template <class T> struct is_array;
template <class T> struct is_pointer;
template <class T> struct is_null_pointer;
template <class T> struct is_member_object_pointer;
template <class T> struct is_member_function_pointer;
template <class T> struct is_enum;
template <class T> struct is_union;
template <class T> struct is_class;
template <class T> struct is_function;
template <class T> struct is_lvalue_reference;
template <class T> struct is_rvalue_reference;

例子:

#include <iostream>
#include <type_traits>
#include <iostream>
#include <type_traits>struct A
{int a;int f(int) { return 2011; }
};enum E
{e = 1,
};union U
{int u;
};int main()
{using namespace std;cout << boolalpha << '\n'; // boolalpha: bool 以 true 或 false输出cout << is_void<void>::value << '\n'; // true                           cout << is_integral<short>::value << '\n'; // truecout << is_floating_point<double>::value << '\n'; // truecout << is_array<int[]>::value << '\n'; // truecout << is_pointer<int*>::value << '\n'; // truecout << is_null_pointer<nullptr_t>::value << '\n'; // truecout << is_member_object_pointer<int A::*>::value << '\n'; // truecout << is_member_function_pointer<int (A::*)(int)>::value << '\n'; // truecout << is_enum<E>::value << '\n'; // truecout << is_union<U>::value << '\n'; // true cout << is_class<string>::value << '\n'; // truecout << is_function<int*(double)>::value << '\n'; // true	cout << is_lvalue_reference<int&>::value << '\n'; // truecout << is_rvalue_reference<int&&>::value << '\n'; // true
}

让我们试着实验一下这个魔法

#include <iostream>
#include <type_traits>
#include <iostream>
#include <type_traits>namespace fx
{template <class T, T v>struct intergral_constant{static constexpr T value = v;using value_type = T;using type = intergral_constant;constexpr operator value_type() const noexcept{return value;}constexpr value_type operator()() const noexcept{return value;}};using true_type = intergral_constant<bool, true>;using false_type = intergral_constant<bool, false>;template <class T>struct is_integral : public false_type{};template <>struct is_integral<bool> : public true_type{};template <>struct is_integral<char> : public true_type{};template <>struct is_integral<signed char> : public true_type{};template <>struct is_integral<unsigned char> : public true_type{};template <>struct is_integral<wchar_t> : public true_type{};template <>struct is_integral<short> : public true_type{};template <>struct is_integral<int> : public true_type{};template <>struct is_integral<long> : public true_type{};template <>struct is_integral<long long> : public true_type{};template <>struct is_integral<unsigned short> : public true_type{};template <>struct is_integral<unsigned int> : public true_type{};template <>struct is_integral<unsigned long> : public true_type{};template <>struct is_integral<unsigned long long> : public true_type{};
}int main(int argc, char* argv[])
{std::cout << fx::is_integral<int>::value << std::endl;}

fx::is_integral<>::value作为返回值,这是元函数的命名约定

自从C++17之后,有了一个更便捷的方式:

template< class T >
inline constexpr bool is_integral_v = is_integral<T>::value

这样可以使用std::integral_v<T>代替std::integral<int>::value

复合类型 Composite Type Categories

Composite data type - Wikipedia

image-20220525233832046

对于主要类型和复合类型,类型萃取库提供类型属性和类型属性查询

类型属性

template <class T> struct is_const;
template <class T> struct is_volatile;
template <class T> struct is_trivial;
template <class T> struct is_trivially_copyable;
template <class T> struct is_standard_layout;
template <class T> struct is_empty;
template <class T> struct is_polymorphic;
template <class T> struct is_abstract;
template <class T> struct is_final;
template <class T> struct is_aggregate;template <class T> struct is_signed;
template <class T> struct is_unsigned;
template <class T> struct is_bounded_array;
template <class T> struct is_unbounded_array;
template <class T> struct is_scoped_enum;template <class T, class... Args> struct is_constructible;
template <class T> struct is_default_constructible;
template <class T> struct is_copy_constructible;
template <class T> struct is_move_constructible;template <class T, class U> struct is_assignable;
template <class T> struct is_copy_assignable;
template <class T> struct is_move_assignable;template <class T, class U> struct is_swappable_with;
template <class T> struct is_swappable;template <class T> struct is_destructible;template <class T, class... Args> struct is_trivially_constructible;
template <class T> struct is_trivially_default_constructible;
template <class T> struct is_trivially_copy_constructible;
template <class T> struct is_trivially_move_constructible;template <class T, class U> struct is_trivially_assignable;
template <class T> struct is_trivially_copy_assignable;
template <class T> struct is_trivially_move_assignable;
template <class T> struct is_trivially_destructible;template <class T, class... Args> struct is_nothrow_constructible;
template <class T> struct is_nothrow_default_constructible;
template <class T> struct is_nothrow_copy_constructible;
template <class T> struct is_nothrow_move_constructible;template <class T, class U> struct is_nothrow_assignable;
template <class T> struct is_nothrow_copy_assignable;
template <class T> struct is_nothrow_move_assignable;template <class T, class U> struct is_nothrow_swappable_with;
template <class T> struct is_nothrow_swappable;template <class T> struct is_nothrow_destructible;template <class T> struct has_virtual_destructor;template <class T> struct has_unique_object_representations;

类型属性查询

template <class T> struct alignment_of;
template <class T> struct rank;
template <class T, unsigned I = 0> struct extent;

template struct has_virtual_destructor;

template struct has_unique_object_representations;


### 类型属性查询```cpp
template <class T> struct alignment_of;
template <class T> struct rank;
template <class T, unsigned I = 0> struct extent;

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

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

相关文章

模板元编程 Template Metaprogramming--- C++ 20

模板元编程(一) Template Metaprogramming— C 20 在编译期进行类型操作 举个例子: std::move在概念上应该这样实现(实际并不是这么做的): static_cast<std::remove_reference<decltype(arg)>::type&&>(arg);意义上,std::move首先获取它的参数arg,推断…

模板元编程(二) Template Metaprogramming ---C++ 20

模板元编程(二) Template Metaprogramming —C 20 现在我们介绍参数与模板参数混合使用 先看一下例子: #include <iostream>int power(int m, int n) {int r 1;for (int k 1; k < n; k) r * m;return r; }template <int m, int n> struct Power {static in…

让窗体获得焦点,一定会有您用到的时候

开发环境&#xff1a;Visual Studio .NET 2005 下的Windows Form Application 应用场景: 当我们有个窗体中的数据发生了变化而此窗体又没有获得焦点(不是用户操作的当前窗口)的时候&#xff0c;我们希望它获得焦点&#xff0c;这样用户就可以立刻发现它上面的数据发生了变化。…

容器和算法的改进 --- C++20

容器和算法的改进 — C20 C 20对容器和算法有很多的改进 std::vector 和std::string支持constexpr所有容器支持consistent container erasure , contains新的算法移动元素 std::shift_left可以检查 std::string 的前缀和后缀 支持 constexpr 的容器和算法 C 20的std::vecto…

CodeSmith基础(二)

本文将介绍CodeSmith与数据库进行交互生成相应的存储过程&#xff0c;本例使用的数据库为SQL Server 2000。 在与数据库进行交互时&#xff0c;我们使用到了一个CodeSmith自带的组件SchemaExplorer&#xff0c;利用这个组件我们可以访问数据库的数据表、存储过程、视图等…

[Android]使用ViewPager实现图片滑动展示

在淘宝等电商的APP首页经常能看到大幅的广告位&#xff0c;通常有多幅经常更新的图片用于展示促销信息&#xff0c;如下图所示&#xff1a; 通常会自动滚动&#xff0c;也可以根据手势滑动。我没有研究过人家的APP是通过什么实现的&#xff0c;可能有第三方已经封装好的控件可以…

c#获取当前应用程序所在路径

一、获取当前文件的路径1. System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName 获取模块的完整路径&#xff0c;包括文件名。2. System.Environment.CurrentDirectory 获取和设置当前目录(该进程从中启动的目录)的完全限定目录。3. System.IO.…

requires表达式 ---C++ 20 模板

requires表达式 —C 20 模板 requires还可以接一个表达式,该表达式也是一个纯右值表达式,表达式为true时满足约束条件,false则不满足约束条件 requires表达式的判定标准:对requires表达式进行模板实参的替换,如果替换之后出现无效类型,或者违反约束条件,则值为false,反之为tr…

童趣

1.豆豆的外婆买了一只母鸡&#xff0c;打算杀了吃。豆豆不允许杀它&#xff0c;外婆就把鸡养在院子里。每天早上&#xff0c;外婆在院子里干家务&#xff0c;豆豆就坐在小板凳上&#xff0c;手里拿了本小画书&#xff0c;绘声绘色地给母鸡讲故事。豆豆给母鸡起的小名是“小鸭”…

PROJECT #1 - BUFFER POOL [CMU 15-445645]笔记

PROJECT #1 - BUFFER POOL 15-445/645笔记 因为在主存中储存所有块是不可能的&#xff0c;我们需要管理主存中用于存储块的可用空间的分配 。缓冲区是主存中用于存储磁盘数据块拷贝的那部分。 缓冲区管理器 ​ 当数据库系统中的程序需要磁盘上的块时&#xff0c;它向缓冲区管…

MS SQL入门基础:系统数据库

SQL Server 2000 有四个系统数据库&#xff08;System Databases&#xff09;&#xff1a;Master、Model、Msdb、Tempdb。这些系统数据库的文件存储在Microsoft SQL Server&#xff08;默认安装目录&#xff09;的MSSQL子目录的Data 文件夹中。各系统数据库所包含的文件如表6-1…

C++20 std::jthread

C20 std::jthread std::jthread 表示 joining thread , 与C11里面的std::thread不同std::jthread 自动join, 并且可以被外部终止 自动join std::thread #include <iostream> #include <thread> using namespace std;int main(int argc, char* argv[]) {std::cou…

.NET资源收集

.NET开发资源精华收集与共享 .Net General微软.Net中文主页 .NET Framework开发中心 微软.Net Framework中文产品支持中心 微软.Net Framework中文新闻组(Web) 微软VB.Net中文新闻组(Web) 博客园 .NET 2.0 专题 孟宪会之精彩世界 微软.NET俱乐部 MSDN中文网络广播 AspxBoy教程网…

C++ 20 内存模型(一)

C 20 内存模型(一) 多线程的基础是优秀的内存模型 C20 内存模型: 高复杂性, 难以理解对多线程有更深入的理解 内存布局 位域 member_name成员名, width bit 宽度 struct bit_field_name {type member_name : width; };struct my_struct {char a;int b : 5; // 最大存储 …