zoukankan      html  css  js  c++  java
  • C++11 tuple元组

    C++11 tuple 元组

    tuple容器(元组), 是表示元组容器, 是不包含任何结构的,快速而低质(粗制滥造, quick and dirty)的, 可以用于函数返回多个返回值;

    tuple容器, 可以使用直接初始化, 和"make_tuple()"初始化, 访问元素使用"get<>()"方法, 注意get里面的位置信息, 必须是常量表达式(const expression);

    可以通过"std::tuple_size<decltype(t)>::value"获取元素数量; "std::tuple_element<0, decltype(t)>::type"获取元素类型;

    如果tuple类型进行比较, 则需要保持元素数量相同, 类型可以比较, 如相同类型, 或可以相互转换类型(int&double);

    无法通过普通的方法遍历tuple容器, 因为"get<>()"方法, 无法使用变量获取值;

    以下代码包含一些基本的用法, 详见注释;

     示例代码:

    /*eclipse cdt, gcc 4.8.1*/  
      
    #include <iostream>  
    #include <vector>  
    #include <string>  
    #include <tuple>  
      
    using namespace std;  
      
    std::tuple<std::string, int>  
    giveName(void)  
    {  
        std::string cw("Caroline");  
        int a(2013);  
        std::tuple<std::string, int> t = std::make_tuple(cw, a);  
        return t;  
    }  
      
    int main()  
    {  
        std::tuple<int, double, std::string> t(64, 128.0, "Caroline");  
        std::tuple<std::string, std::string, int> t2 =  
                std::make_tuple("Caroline", "Wendy", 1992);  
      
        //返回元素个数  
        size_t num = std::tuple_size<decltype(t)>::value;  
        std::cout << "num = " << num << std::endl;  
      
        //获取第1个值的元素类型  
        std::tuple_element<1, decltype(t)>::type cnt = std::get<1>(t);  
        std::cout << "cnt = " << cnt << std::endl;  
      
        //比较  
        std::tuple<int, int> ti(24, 48);  
        std::tuple<double, double> td(28.0, 56.0);  
        bool b = (ti < td);  
        std::cout << "b = " << b << std::endl;  
      
        //tuple作为返回值  
        auto a = giveName();  
        std::cout << "name: " << get<0>(a)  
                << " years: " << get<1>(a) << std::endl;  
      
        return 0;  
    }  

    输出结果:

    num = 3  
    cnt = 128  
    b = 1  
    name: Caroline years: 2013  

    C++ pair 点对

    1 pair的应用

    pair是将2个数据组合成一个数据,当需要这样的需求时就可以使用pair,如stl中的map就是将key和value放在一起来保存。另一个应用是,当一个函数需要返回2个数据的时候,可以选择pair。 pair的实现是一个结构体,主要的两个成员变量是first second 因为是使用struct不是class,所以可以直接使用pair的成员变量。

    2 make_pair函数

    template pair make_pair(T1 a, T2 b) { return pair(a, b); }

    很明显,我们可以使用pair的构造函数也可以使用make_pair来生成我们需要的pair。 一般make_pair都使用在需要pair做参数的位置,可以直接调用make_pair生成pair对象很方便,代码也很清晰。 另一个使用的方面就是pair可以接受隐式的类型转换,这样可以获得更高的灵活度。灵活度也带来了一些问题如:

    std::pair<int, float>(1, 1.1);

    std::make_pair(1, 1.1);

    是不同的,第一个就是float,而第2个会自己匹配成double。

    类模板:template <class T1, class T2> struct pair

    参数:T1是第一个值的数据类型,T2是第二个值的数据类型。

    功能:pair将一对值组合成一个值,这一对值可以具有不同的数据类型(T1和T2),两个值可以分别用pair的两个公有函数first和second访问。

    具体用法:

    1.定义(构造):

    1     pair<int, double> p1;  //使用默认构造函数
    2     pair<int, double> p2(1, 2.4);  //用给定值初始化
    3     pair<int, double> p3(p2);  //拷贝构造函数

    2.访问两个元素(通过first和second):

    1     pair<int, double> p1;  //使用默认构造函数
    2     p1.first = 1;
    3     p1.second = 2.5;
    4     cout << p1.first << ' ' << p1.second << endl;

    输出结果:1 2.5

    3.赋值operator = :

    (1)利用make_pair:

    1     pair<int, double> p1;
    2     p1 = make_pair(1, 1.2);

    (2)变量间赋值:

        pair<int, double> p1(1, 1.2);
        pair<int, double> p2 = p1;
    
    

    Pair类型概述

    pair是一种模板类型,其中包含两个数据值,两个数据的类型可以不同,基本的定义如下:

    pair<int, string> a;

    表示a中有两个类型,第一个元素是int型的,第二个元素是string类型的,如果创建pair的时候没有对其进行初始化,则调用默认构造函数对其初始化。

    pair<string, string> a("James", "Joy");

    也可以像上面一样在定义的时候直接对其初始化。

    由于pair类型的使用比较繁琐,因为如果要定义多个形同的pair类型的时候,可以时候typedef简化声明:

    typedef pair<string, string> author;

    author pro("May", "Lily");

    author joye("James", "Joyce");

    Pair对象的操作

    • 对于pair类,由于它只有两个元素,分别名为first和second,因此直接使用普通的点操作符即可访问其成员

    pair<string, string> a("Lily", "Poly"); 

    string name;

    name = pair.second;

    • 生成新的pair对象

    可以使用make_pair对已存在的两个数据构造一个新的pair类型:

    int a = 8;

    string m = "James";

    pair<int, string> newone;

    newone = make_pair(a, m);

  • 相关阅读:
    HAProxy、Keepalived 在 Ocatvia 的应用实现与分析
    Octavia 的 HTTPS 与自建、签发 CA 证书
    Octavia 创建 loadbalancer 的实现与分析
    OpenStack Rally 质量评估与自动化测试利器
    自建 CA 中心并签发 CA 证书
    Failed building wheel for netifaces
    通过 vSphere WS API 获取 vCenter Datastore Provisioned Space 置备空间
    OpenStack Placement Project
    我们建了一个 Golang 硬核技术交流群(内含视频福利)
    没有图形界面的软件有什么用?
  • 原文地址:https://www.cnblogs.com/lsgxeva/p/8250879.html
Copyright © 2011-2022 走看看