Modern C++ std::get<n>(tuple)的原理

1. 前言

前面我们讲过std::tuple的实现原理,但没有讲如何取出数据,本节着重讲讲这点。本节与之前的blog有较大关联,如果您没看,这里有链接,链接已按由浅入深排好序,您可以按顺序阅读。如果时间少可以直接看第三篇由工具快速理解std::tuple的实现原理:

  1. Modern C++ std::unique_ptr的实现原理 带出size问题
  2. Modern C++ std::tuple的size 编程实验size问题
  3. Modern C++利用工具快速理解std::tuple的实现原理 快速理解std::tuple的实现原理
  4. GDB调试技巧实战–自动化画出类关系图 写一个普世工具结合GDB自动画类关系图,当然也适用std::tuple
  5. Modern C++ sizeof(std::tuple)的秘密及实现代码解读 从源码理解std::tuple的实现

2. 按图索骥

原理也不难,根据要取的数据是空类还是非空类分两种情况,先上图,懂了就不必往下看了。

请添加图片描述
实验代码贴在这,方便大家从copy试验:

#include<iostream>
#include <tuple>
using namespace std;

struct Empty{
   
        constexpr Empty() noexcept = default;
};

std::tuple<int,Empty,Empty,int> ie2i = {
   1, Empty(), Empty(), 2};//12
        auto& ie2i_0 = std::get<0>(ie2i);
        auto& ie2i_1 = std::get<1>(ie2i);
        auto& ie2i_2 = std::get<2>(ie2i);
        auto& ie2i_3 = std::get<3>(ie2i);
        std::cout<<"sizeof(std::tuple<int,Empty,Empty,int>):"<<sizeof(std::tuple<int,Empty,Empty,int>)<<std::endl;
        std::cout<<"ie2i addr:"<<&ie2i<<" ie2i_3:"<<&ie2i_3<<" ie2i_2:"<<&ie2i_2<<" ie2i_1:"<<&ie2i_1<<" ie2i_0:"<<&ie2i_0<<std::endl<<std::endl;

3. 看代码实现

3.1 先看取第一个元素:类型为int,值为1

在这里插入图片描述
注意下面由__t转换为__b, 即从类型std::_Tuple_impl<0, int, Empty, Empty, int> &转成了std::_Head_base<0, int, false> &,而且偏移加了8,说明在std::tuple<int,Empty, Empty, int>这个大房子里std::_Head_base<0, int, false> 位于+8处的偏房中。偏移大小和对象内存模型相关,我们不去讨论。
在这里插入图片描述

3.2 再看取第二个元素:类型为Empty:

在这里插入图片描述
地址从d4f0跳到了d4f4, 说明在std::tuple<int,Empty, Empty, int>这个大房子里std::_Head_base<1, Empty, true> 位于+4处的偏房中, 这一点可以由下面的反汇编代码证明():
在这里插入图片描述
$rax偷偷加了4传给了_M_head(_Head_base& __b)

/usr/include/c++/8/tuple
  72   template<std::size_t _Idx, typename _Head>
  73     struct _Head_base<_Idx, _Head, true>
  74     : public _Head
  75     {
   
... ...
 112       static constexpr _Head&
 113       _M_head(_Head_base& __b) noexcept {
    return __b; }

相关推荐

  1. 新知识-Tuple元组使用

    2024-02-01 10:46:01       54 阅读
  2. 关于样本方差分母是 ( n-1 ) 而不是 ( n )原因

    2024-02-01 10:46:01       32 阅读
  3. python中tuple、int和float内置方法

    2024-02-01 10:46:01       56 阅读
  4. C++(14):获取类型在tuple索引

    2024-02-01 10:46:01       50 阅读
  5. Python:list列表与tuple元组区别

    2024-02-01 10:46:01       57 阅读
  6. Python-元组(Tuple)列表(List)区别

    2024-02-01 10:46:01       36 阅读
  7. Python - tuple

    2024-02-01 10:46:01       25 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-01 10:46:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-01 10:46:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-01 10:46:01       87 阅读
  4. Python语言-面向对象

    2024-02-01 10:46:01       96 阅读

热门阅读

  1. 如何降低视频RTSP解码延迟

    2024-02-01 10:46:01       59 阅读
  2. 测试pytorch(GPU)安装,并输出版本号

    2024-02-01 10:46:01       59 阅读
  3. 第二章 Redis介绍及安装

    2024-02-01 10:46:01       59 阅读
  4. 人工智能在现代科技中的应用和未来发展趋势

    2024-02-01 10:46:01       66 阅读
  5. vivado 时钟规划

    2024-02-01 10:46:01       52 阅读
  6. C语言-算法-搜索剪枝与记忆化搜索

    2024-02-01 10:46:01       56 阅读
  7. 【无标题】

    2024-02-01 10:46:01       57 阅读