#include<iostream>

#include<boost/tuple/tuple.hpp>

#include<boost/variant.hpp>

#include<boost/tuple/tuple_io.hpp>

#include<boost/any.hpp>

#include<vector>

#include<iterator>

#include<string>



using namespace std;



boost::tuple<std::string, int> func()

    {

      return boost::make_tuple("Error message", 2009);

    }



std::vector<boost::any> vector1;



struct output : public boost::static_visitor<>

{

  template <typename T>

  void operator()(T &t) const

  {

    vector1.push_back(t);

  }

};





int main(){

    //Boost.Tuple 还提供了一种叫做 Tier 的特殊元组。 Tier 的特殊之处在于它包括的全部元素都是引用类型的。 它能够通过构造函数 boost::tie() 来创建。

int i;    char c;    double d;

    boost::tie(i,c,d) = boost::tuple<int,char,double>(1,'A',0.618);

    d = 0.718;

    cout<<d<<endl;





    //用ignore忽略元素

    char c2;

    boost::tie(boost::tuples::ignore,c2) = std::make_pair(1,'a');

    cout<<c2<<endl;



    //boost::tie() 在一定程度上简化了语法。 同一时候, 也能够用作“拆箱”元组。 在接下来的这个样例里, 元组中的各个元素就被非常方便的“拆箱”并直接赋给了其它变量。



    std::string errmsg;

    int errcode;



    boost::tie(errmsg, errcode) = func();

    std::cout << errmsg << ": " << errcode << std::endl;

    //Boost.Variant 为我们提供了一个定义在 boost/variant.hpp 中的类: boost::variant 。 既然 boost::variant 是一个模板。 你必需要指定至少一个參数。

Variant 所存储的数据类型就由这些參数来指定。

上面的样例就给 v 指定了 double 类型和 char 类型。

注意, 一旦你将一个 int 值赋给了 v, 你的代码将不会编译通过。



    //当然。 上面的样例也能够用一个 union 类型来实现, 可是与 union 不同的是: boost::variant 能够储存像 std::string 这种 class 类型的数据。

//boost::apply_visitor() 第一个參数需要传入一个继承自 boost::static_visitor 类型的对象。

这个类必需要重载 operator()() 运算符来处理 boost::variant 每一个可能的类型。

对应的, 样例中的 v 就重载了三次 operator() 来处理三种可能的类型: double, char 和 std::string。



    //再细致看代码, 不难发现 boost::static_visitor 是一个模板。 那么。当 operator()() 有返回值的时候, 就必须返回一个模板才行。 假设 operator() 像样例那样没有返回值时。 你就不须要模板了。



    //boost::apply_visitor() 的第二个參数是一个 boost::variant 类型的值。

//在使用时, boost::apply_visitor() 会自己主动调用跟第二个參数匹配的 operator()() 。

演示样例程序中的 boost::apply_visitor() 就自己主动调用了三个不同的 operator 第一个是 double 类型的, 第二个是 char 最后一个是 std::string。



    //boost::apply_visitor() 的长处不仅仅是“自己主动调用匹配的函数”这一点。 更实用的是, boost::apply_visitor() 会确认是否 boost::variant 中的每一个可能值都定义了对应的函数。 假设你忘记重载了不论什么一个函数, 代码都不会编译通过。



    boost::variant<double, char, std::string> v;

    v = 3.14;

    boost::apply_visitor(output(), v);

    v = 'A';

    boost::apply_visitor(output(), v);

    v = "Hello, world!";

    boost::apply_visitor(output(), v);



}

编译后输出:

0.718

a

Error message: 2009

boost::tie()和boost::variant()解说的更多相关文章

  1. 以boost::function和boost:bind取代虚函数

    转自:http://blog.csdn.net/Solstice/archive/2008/10/13/3066268.aspx 这是一篇比较情绪化的blog,中心思想是“继承就像一条贼船,上去就下不 ...

  2. boost::string or boost::regex

    有时候写代码时会遇到下面问题 如果有一个文本文件,其包括内容类似于C语言,当中有一行例如以下格式的语句: layout (local_size_x = a,local_size_y = b, loca ...

  3. [置顶] 编程模仿boost::function和boost::bind

    boost::function和boost::bind结合使用是非常强大的,他可以将成员函数和非成员函数绑定对一个对象上,实现了类似C#的委托机制.委托在许多时候可以替代C++里面的继承,实现对象解耦 ...

  4. 用boost::bind构造boost::coroutine

    class TestCoro { ... typedef boost::coroutines::coroutione<void ()> Coro; void CoroFun(Coro::c ...

  5. 一起学习Boost标准库--Boost.StringAlgorithms库

    概述 在未使用Boost库时,使用STL的std::string处理一些字符串时,总是不顺手,特别是当用了C#/Python等语言后trim/split总要封装一个方法来处理.如果没有形成自己的com ...

  6. boost::unique_lock和boost::lock_guard的区别

    lock_guard unique_lock boost::mutex mutex; boost::unique_lock<boost::mutex> lock(mutex); std:: ...

  7. boost::function和boost:bind取代虚函数

    以boost::function和boost:bind取代虚函数 这是一篇比较情绪化的blog,中心思想是"继承就像一条贼船,上去就下不来了",而借助boost::function ...

  8. boost::bind和boost::function使用示例

    C++11已支持bind和function,之前的不支持,但可以借助boost达到同样目的.看如下两段代码: 1) 创建HDFS目录 void hdfs::init() { if (0 == hdfs ...

  9. boost::function 通过boost::bind调用类成员函数

    1. 首先引用boost::function和boost::bind的头文件和库: #include "boost/bind.hpp" #include "boost/f ...

随机推荐

  1. Python168的学习笔记7

    关于多线程操作. 对于IO操作,如访问网站,写入磁盘这种需要时间等待响应的操作,多个cpu也几乎不能提高效率. 对于CPU密集型操作,如这个格式转换,可以通过多个cpu同时去进行. 但是对于pytho ...

  2. Ajax提交进度显示实例

    概述:ajax提交比较大的文件的时候,我们希望能够看到它上传的进度,代码放下面了. <!DOCTYPE html> <html> <head> <meta c ...

  3. elasticsearch ik中文分词器安装

    特殊说明:灰色文字用来辅助理解的. 安装IK中文分词器 我在百度上搜索了下,大多介绍的都是用maven打包下载下来的源码,这种方法也行,但是不够方便,为什么这么说? 首先需要安装maven吧?其次需要 ...

  4. interfacer和abstarct class的异同

  5. Java_tomcat thread dump 分析

    前言 Java Thread Dump 是一个非常有用的应用诊断工具, 通过thread dump出来的信息, 可以定位到你需要了解的线程, 以及这个线程的调用栈. 如果配合linux的top命令, ...

  6. Asky极简教程:零基础1小时学编程,已更新前8节

    Asky极简架构 开源Asky极简架构.超轻量级.高并发.水平扩展.微服务架构 <Asky极简教程:零基础1小时学编程>开源教程 零基础入门,从零开始全程演示,如何开发一个大型互联网系统, ...

  7. 我对NHibernate的感受(1):对延迟加载方式的误解

    NHibernate是.NET平台上最著名的ORM框架,虽说出身于Java平台上的Hibernate,但是从外部看来这几乎就是一个.NET平台上的原生产品:有自己的社区,有自己的用户,有自己的商业支持 ...

  8. 跟我一起学extjs5(08--自己定义菜单1)

    跟我一起学extjs5(08--自己定义菜单1) 顶部和底部区域已经作好,在顶部区域有一个菜单的button.这一节我们设计一个菜单的数据结构,使其能够展示出不相同式的菜单.因为准备搭建的是一个系统模 ...

  9. 分布式消息系统Kafka初步(一) (赞)

    终于可以写kafka的文章了,Mina的相关文章我已经做了索引,在我的博客中置顶了,大家可以方便的找到.从这一篇开始分布式消息系统的入门. 在我们大量使用分布式数据库.分布式计算集群的时候,是否会遇到 ...

  10. [Android] repo 下载Android源码(国内镜像)

    reference : http://blog.csdn.net/shenlan18446744/article/details/51490560 repo 下载Android源码(国内镜像) 下载r ...