#include<iostream>

#include<string>

#include<boost/tuple/tuple.hpp>

#include<boost/tuple/tuple_io.hpp>

#include <boost/tuple/tuple_comparison.hpp>



using namespace std;



int main(){

    //boost::tuple 扩展了 C++ 的数据类型 std::pair 用以储存多个而不仅仅是两个值。

//除了 boost::tuple。 这一章还涵盖了类 boost::any 和 boost::variant 以储存那些不确定类型的值。

当中 boost::any 类型的变量使用起来就像弱类型语言中的变量一样灵活。 还有一方面, boost::variant 类型的变量能够储存一些提前定义的数据类型, 就像我们用 union 时候一样。

    typedef boost::tuple<std::string, std::string> person1;

    person1 p1("Boris", "Schaeling");

    cout << p1 << std::endl;

    //就像 std::pair 有辅助函数 std::make_pair() 一样, 一个元组也能够用它的辅助函数 boost::make_tuple() 来创建。

    std::cout << boost::make_tuple("Boris", "Schaeling", 43) << std::endl;



     //一个元组也能够存储引用类型的值。

     std::string s = "Boris";

     std::cout << boost::make_tuple(boost::ref(s), "Schaeling", 43) << std::endl;



     //由于 "Schaeling" 和 43 是按值传递的,所以就直接存储在了元组中。 与他们不同的是: person 的第一个元素是一个指向 s 的引用。 Boost.Ref 中的 boost::ref() 就是用来创建这种引用的。

相对的。 要创建一个常量的引用的时候, 你须要使用 boost::cref() 。



     //在学习了创建元组的方法之后, 让我们来了解一下訪问元组中元素的方式。

std::pair 仅仅包括两个元素。 故能够使用属性 first 和 second 来訪问当中的元素。

但元组能够包括无限多个元素, 显然。 我们须要用还有一种方式来解决訪问的问题。



     typedef boost::tuple<std::string, std::string, int> person2;

     person2 p2 = boost::make_tuple("Boris", "Schaeling", 43);

     std::cout << p2.get<0>() << std::endl;

     std::cout << boost::get<0>(p2) << std::endl;



     //我们能够用两种方式来訪问元组中的元素: 使用成员函数 get() , 或者将元组传给一个独立的函数 boost::get() 。 使用这两种方式时, 元素的索引值都是通过模板參数来指定的。

样例中就分别使用了这两种方式来訪问 p 中的第一个元素。

因此, Boris 会被输出两次。



     //另外。 对于索引值合法性的检查会在编译期执行, 故訪问非法的索引值会引起编译期错误而不是执行时的错误。



     //对于元组中元素的改动。 你相同能够使用 get() 和 boost::get() 函数。

typedef boost::tuple<std::string, std::string, int> person3;

     person3 p3 = boost::make_tuple("Boris", "Schaeling", 43);

     p3.get<1>() = "Becker";

     std::cout << p3 << std::endl;



     //get() 和 boost::get() 都会返回一个引用值。 样例中改动了 lastname 之后将会输出: (Boris Becker 43) 。

//Boost.Tuple 除了重载了流操作运算符以外, 还为我们提供了比較运算符。 为了使用它们, 你必需要包括对应的头文件: boost/tuple/tuple_comparison.hpp 。



     typedef boost::tuple<std::string, std::string, int> person4;

     person4 p4 = boost::make_tuple("Boris", "Schaeling", 43);

     person4 p5 = boost::make_tuple("Boris", "Becker", 43);

     std::cout << (p4 != p5) << std::endl;



     //上面的样例将会输出 1 由于两个元组 p1 和 p2 是不同的。





}

编译后输出:

(Boris Schaeling)

(Boris Schaeling 43)

(Boris Schaeling 43)

Boris

Boris

(Boris Becker 43)

1

boost::tuple 深入学习解说的更多相关文章

  1. 【Todo】Boost安装与学习

    现在这里找下载包 http://sourceforge.net/projects/boost 我找的是 1_62_0 下面是从公司wiki上找到的一个说明. boost & thrift安装步 ...

  2. boost tuple

    boost::tuple is a generalized version of std::pair. While std::pair can only store exactly two value ...

  3. Boost线程库学习笔记

    一.创建一个线程 创建线程 boost::thread myThread(threadFun); 需要注意的是:参数可以是函数对象或者函数指针.并且这个函数无参数,并返回void类型. 当一个thre ...

  4. boost asio io_service学习笔记

    构造函数 构造函数的主要动作就是调用CreateIoCompletionPort创建了一个初始iocp. Dispatch和post的区别 Post一定是PostQueuedCompletionSta ...

  5. boost timer代码学习笔记

    socket连接中需要判断超时 所以这几天看了看boost中计时器的文档和示例 一共有五个例子 从简单的同步等待到异步调用超时处理 先看第一个例子 // timer1.cpp: 定义控制台应用程序的入 ...

  6. Boost.Coroutine2:学习使用Coroutine(协程)

    function(函数)routine(例程)coroutine (协程) 函数,例程以及协程都是指一系列的操作的集合. 函数(有返回值)以及例程(没有返回值)也被称作subroutine(子例程), ...

  7. 初探boost之noncopyable学习笔记

    noncopyable 功能 同意程序轻松实现一个不可复制的类. 需包括头文件 #include<boost/noncopyable.hpp>     或 #include<boos ...

  8. Python tuple元组学习

    1.tuple和list非常类似,但是tuple一旦初始化就不能修改 classmates = ('Michael', 'Bob', 'Tracy') 现在,classmates这个tuple不能变了 ...

  9. std::locale与boost::locale的学习

    1. 什么是facet, locale facet ['fæsɪt]的原意,是宝石切割出来的一个平面. locale[ləʊˈkæl],表示本地化, locale the container that ...

随机推荐

  1. 修改linux内核的启动logo和禁用启动光标【转】

    本文转载自:http://blog.csdn.net/hunanchenxingyu/article/details/40992947 1-1.制作logo的方法: 首先选择一个自己喜欢的图片,png ...

  2. 【POJ 2096】 Collecting Bugs

    [题目链接] http://poj.org/problem?id=2096 [算法] 概率DP [代码] #include <algorithm> #include <bitset& ...

  3. 2-1 Restful中HTTP协议介绍

    Restful是一种基于资源的软件架构风格,所以从定义上来说是跟HTTP无关的.但是本课程提到的Restful API是基于HTTP协议的一种实现.所有相关知识都是基于现有的HTTP协议而来,并没有对 ...

  4. js设计模式-享元模式

    享元模式实际上是一种优化模式,目的在于提高系统的性能和代码的效率. 使用享元模式的条件:最重要的条件是网页中必须使用了大量资源密集型对象,如果只会用到了少许这类对象,那么这种优化并不划算.第二个条件是 ...

  5. C++中值传递(pass-by-value)和引用传递(pass-by-reference)

    1.pass-by-value的情况: 缺省情况C++以pass-by-value(继承C的方式)传递对象至(或来自)函数.函数参数都是以实际参数的复件为初值,调用端所获得的也是函数返回值的一个复件, ...

  6. js判断浏览器是android还是ios还是微信浏览器

    第一种方法<script type="text/javascript"> //判断访问终端 var browser={ versions:function(){ var ...

  7. hdu 1087 A Plug for UNIX 最大流

    题意:http://www.phpfans.net/article/htmls/201012/MzI1MDQw.html 1.在一个会议室里有n种插座,每种插座一个: 2.每个插座只能插一种以及一个电 ...

  8. ERROR 1840 (HY000) at line 24: @@GLOBAL.GTID_PURGED can only be set when @@GLOBA

    在MySQL 5.7版本中,备份迁移数据库的时候,还原时提示如下报错信息 ERROR 1840 (HY000) at line 24: @@GLOBAL.GTID_PURGED can only be ...

  9. chrome模拟微信

    这里有一个模拟器,既可以设置模拟很多型号的手机设备,也可以伪造你想要的HTTP_USER_AGENT.选择USER_AGENT,选other,微信的HTTP_USER_AGENT是: 在iPhone下 ...

  10. 00-- 关于C++ const 的全面总结

    转:关于C++ const 的全面总结 C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性,本人根据各方面查到的资料进行总结如下,期望对朋友们有所帮助. Const 是C ...