boost.tuple 类型 容器相关的

2024-06-15 03:32
文章标签 类型 相关 容器 boost tuple

本文主要是介绍boost.tuple 类型 容器相关的,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 Boost::tuple

和pair有些类似,pair是只能容纳两个类型的对象

boost.typle是std:pair的延伸
可以将std:pair视作boost.tuple的一个特例
std::pair主要的作用是将两个数据组合成一个数据
C++中std::vector<std::pair<double,double> >
与std.pair不同的是boost.tuple可以容纳更多数量的元素

booost.tuple的典型用途:
作为函数的返回值,可以支持两个以上的返回值
将多个相关的类型组合起来
tuple元素必须有可用的构造函数.复制函数.赋值操作

目前tuple元素个数最多为10个

  很多的时候我们经常需要为我们的函数返回多个值,一般的做法是通过传入非常量的指针或引用,但是这样的话可能可读性就要差一些,使用者可能需要确切的文档才能确定到底哪个是返回值,为了更好的可读性,我们可以使用class或struct来封装我们要返回的多个值,然后返回封装struct或class,但是使用这种方法的弊端就是增加的程序的代码量,最好的解决办法其实我们可以通过一种匿名的struct或class来解决这个问题。
    
    Boost::tuple就为我们提供了一种类似于匿名struct的方法为我们解决函数的多个返回值的问题。既增强了代码的可读性有不增加代码量。其实在STL中已经有这样的特例,std::pair其实就是boost::tuple的2个参数的特例,对boost::tuple你可以绑定更多的参数,或者你可以迭代实现无限多参数的情况。

二 源码剖析

头文件: "boost/tuple/tuple.hpp",它包含了 tuple 类模板及库的核心部分。

头文件: "boost/tuple/tuple_io.hpp",包含了对 tuple 的输入输出操作符。

头文件: "boost/tuple/tuple_comparison.hpp",包含了 tuple 的关系操作符。

为了方便使用,Tuple 库中有些名字位于名字空间 boost:如 tuple, make_tuple, tie, 和 get.

函数说明:

  1)构造函数
  2)拷贝构造函数
  3)t.get<N>()或get<N>(t) ,取得第N个值
  4)make_tuple ,生成tuple
  5)tie , 生成都是ref的tuple
  6) 重载比较运算符 ,可以直接用来比较
  7)重载输入输出运算符 ,可以直接使用IO
  8)get_head()和get_tail()函数,用来取得值
  9)length<>和element<>用来得到tuple的size和第N个的值类型
 10)如果使用boost::TR1,则还可以使用std::tr1::tuple_size(),std::tr1::tuple_element(),分别用来得到tuple的size和第N个值的类型。


三 实例

   1)tuple的构造,拷贝构造函数,get成员函数,get全局函数,make_tuple全局函数。

#include <string>
#include <iostream>
#include "boost/tuple/tuple.hpp"boost::tuples::tuple<int,double> get_values()
{  return boost::make_tuple(6,12.0);
}
class base 
{
public:  virtual ~base() {}; virtual void test() {    std::cout << "base::test()\n"; }
};
class derived : public base 
{
public:  virtual void test() { std::cout << "derived::test()\n"; }
};void main()
{// test for constructorboost::tuple<int,double,std::string>  triple(42,3.14,"My first tuple!");boost::tuple<short,int,long> another;boost::tuple<int,int,double> another2(10);// test for make_tuple , ref and cref functionint plain=42;int& ref=plain;const int& cref=ref;boost::tuples::tuple<int> plaint(plain);plaint = boost::make_tuple(plain);plaint = boost::make_tuple(ref);plaint = boost::make_tuple(cref);boost::tuples::tuple<int&>     reft(ref);boost::make_tuple(boost::ref(plain));boost::make_tuple(boost::ref(ref));boost::make_tuple(boost::ref(cref));boost::tuples::tuple<const int&> creft(cref);boost::make_tuple(boost::cref(plain));boost::make_tuple(boost::cref(ref));boost::make_tuple(boost::cref(cref));// test for get functionboost::tuple<int,double,std::string> triple2(42,3.14,"The amazing tuple!"); int i=boost::tuples::get<0>(triple2);  double d=triple2.get<1>(); std::string s=boost::get<2>(triple2);   // test for function return tupleboost::tuples::tuple<int,double> value = get_values();// test for copy constructor boost::tuple<int,std::string,derived> tup1(-5,"Tuples"); boost::tuple<unsigned int,std::string,base> tup2; tup2=tup1;  tup2.get<2>().test(); std::cout << "Interesting value: "     << tup2.get<0>() << '\n'; const boost::tuple<double,std::string,base> tup3(tup2);  //tup3.get<0>()=3.14; // error, because tup3 is constboost::tuples::tuple<int,int,double> tuple1(10,30,20.000);int head = tuple1.get_head();int tailhead = tuple1.get_tail().get_head();double tail = tuple1.get_tail().get_tail().get_head();// for TR1/*boost::tuples::tuple<double, char, int> tuplesize;    std::tr1::tuple_size();std::tr1::tuple_element();*/}

使用tie函数模版来生成对ref的绑定的tuple,

tie创建一个所有元素类型为非const引用的tuple

tuple的比较使用,tuple的输入输出:

#include <string>
#include <iostream>
#include <vector>
#include <algorithm>
#include "boost/tuple/tuple.hpp"
#include "boost/tuple/tuple_comparison.hpp"
#include "boost/tuple/tuple_io.hpp"
template <int Index> 
class element_less
{
public:  template <typename Tuple>   bool operator()(const Tuple& lhs,const Tuple& rhs) const {   return boost::get<Index>(lhs)<boost::get<Index>(rhs); } 
};
int main()
{// Tiers are tuples, where all elements are of non-const reference types.// They are constructed with a call to the tie function template     int i; char c; double d; boost::tie(i, c, d) = boost::make_tuple(1,'a', 5.5);std::cout << i << " " <<  c << " " << d << std::endl;// test ignorechar ch;boost::tie(boost::tuples::ignore, ch) = std::make_pair(1, 'a');std::cout << ch << std::endl;// test for comparisonboost::tuple<int,std::string> tup1(11,"Match?"); boost::tuple<short,std::string> tup2(12,"Match?"); std::cout << std::boolalpha;  std::cout << "Comparison: tup1 is less than tup2\n";  std::cout << "tup1==tup2: " << (tup1==tup2) << '\n';  std::cout << "tup1!=tup2: " << (tup1!=tup2) << '\n'; std::cout << "tup1<tup2: " << (tup1<tup2) << '\n';  std::cout << "tup1>tup2: " << (tup1>tup2) << '\n';  std::cout << "tup1<=tup2: " << (tup1<=tup2) << '\n'; std::cout << "tup1>=tup2: " << (tup1>=tup2) << '\n'; tup2.get<0>()=boost::get<0>(tup1); //tup2=tup1 also works  std::cout << "\nComparison: tup1 equals tup2\n";  std::cout << "tup1==tup2: " << (tup1==tup2) << '\n';  std::cout << "tup1!=tup2: " << (tup1!=tup2) << '\n'; std::cout << "tup1<tup2: " << (tup1<tup2) << '\n'; std::cout << "tup1>tup2: " << (tup1>tup2) << '\n'; std::cout << "tup1<=tup2: " << (tup1<=tup2) << '\n';std::cout << "tup1>=tup2: " << (tup1>=tup2) << '\n';//test tuple using in the containertypedef boost::tuple<short,int,long,float,double,long double>  num_tuple;std::vector<num_tuple> vec;  vec.push_back(num_tuple(6,2));vec.push_back(num_tuple(7,1)); vec.push_back(num_tuple(5));  std::sort(vec.begin(),vec.end(),element_less<1>()); std::cout << "\nAfter sorting: " <<     vec[0].get<0>() << '\n' <<    vec[1].get<0>() << '\n' <<    vec[2].get<0>() << '\n\n';// test for ioboost::tuple<float, int, std::string> a(1.0f,  2, std::string("Howdy folks!"));std::cout << std::endl << a << std::endl; boost::tuple<int, int, int> ii;std::cin >> ii;std::cout << boost::tuples::set_open('[') << boost::tuples::set_close(']')<< boost::tuples::set_delimiter(':');std::cout << ii << std::endl;    boost::tuples::tuple<int,int,double> tuple1;int head = tuple1.get_head();double tail = tuple1.get_tail();}

四 注意

1)函数 make_tuple 类似于 std::make_pair. 缺省情况下,make_tuple 设置元素类型为非const, 非引用的,即是最简单的、根本的参数类

型。

2)为了使一个 tuple 的元素设为引用类型,你要使用函数 boost::ref, 它来自另一个名为 Boost.Ref 的 Boost 库。

3)如果元素需要是 const 引用的,就使用来自 Boost.Ref 的 boost::cref。

4)如果你要使绑定的每个元素变量都为ref,则可以使用tie函数。



这篇关于boost.tuple 类型 容器相关的的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

如何将Tomcat容器替换为Jetty容器

《如何将Tomcat容器替换为Jetty容器》:本文主要介绍如何将Tomcat容器替换为Jetty容器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat容器替换为Jetty容器修改Maven依赖配置文件调整(可选)重新构建和运行总结Tomcat容器替

JavaScript Array.from及其相关用法详解(示例演示)

《JavaScriptArray.from及其相关用法详解(示例演示)》Array.from方法是ES6引入的一个静态方法,用于从类数组对象或可迭代对象创建一个新的数组实例,本文将详细介绍Array... 目录一、Array.from 方法概述1. 方法介绍2. 示例演示二、结合实际场景的使用1. 初始化二

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

SpringBoot接收JSON类型的参数方式

《SpringBoot接收JSON类型的参数方式》:本文主要介绍SpringBoot接收JSON类型的参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、jsON二、代码准备三、Apifox操作总结一、JSON在学习前端技术时,我们有讲到过JSON,而在

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2