怎样使用RabbitMQ盛放自己定义的对象呢?一般都会使用序列化工具在投放之前转换一次。从MQ取回的时候再逆序列化还原为本地对象。这里使用C++自带的强制类型装换,将本地对象的内存模型当做自然的序列化之后的数据,直接当做字节流放到string对象中,从MQ取回的时候用相同的方法再将string对象强制当做字节流转换为本地对象。

直接使用。非常棒

注意:这样的思路事实上有一个缺点就是本地上传,取回本地使用肯定是没问题的。假设本地上传,其它机器使用(本地是大端机器,其它机器是小端机器)就可能有问题,这也是序列化保证跨语言。跨机器的地方。

Student.h

  1. #pragma once
  2. #include <string>
  3. using namespace std;
  4. #include <iostream>
  5.  
  6. class Student
  7. {
  8. public:
  9. Student(void);
  10. ~Student(void);
  11. string id(void) const ;
  12. void id(const string& id);
  13. int age(void) const ;
  14. void age(const int age);
  15. char* name(void) const ;
  16. void name(const char* name);
  17. char sex(void) const ;
  18. void sex(const char sex);
  19. friend ostream& operator<< (ostream& os ,const Student& stu);
  20. private:
  21. Student(const Student&);
  22. Student& operator=(const Student&);
  23. string id_;
  24. int age_;
  25. char name_[10];
  26. char sex_;
  27. };

Student.cpp

  1. #include "Student.h"
  2.  
  3. Student::Student(void):sex_(0),age_(0)
  4. {
  5. for (int i=0 ;i< 10;i++)
  6. {
  7. name_[i] = 0;
  8. }
  9. }
  10.  
  11. Student::~Student(void)
  12. {
  13. }
  14.  
  15. string Student::id(void) const
  16. {
  17. return id_;
  18. }
  19. void Student::id(const string& id)
  20. {
  21. this->id_ = id;
  22. }
  23. int Student::age(void) const
  24. {
  25. return age_;
  26. }
  27. void Student::age(const int age)
  28. {
  29. age_ = age ;
  30. }
  31. char* Student::name(void) const
  32. {
  33. return (char*)name_;
  34. }
  35. void Student::name(const char* name)
  36. {
  37. char* pname = this->name_;
  38.  
  39. while((*pname++ = *name++) != '\0')
  40. {
  41.  
  42. }
  43. }
  44.  
  45. char Student::sex(void) const
  46. {
  47. return sex_;
  48. }
  49. void Student::sex(const char sex)
  50. {
  51. sex_ = sex;
  52. }
  53.  
  54. ostream& operator<<(ostream& os ,const Student& stu)
  55. {
  56. os<<"id : "<<stu.id()
  57. <<" name : "<<stu.name()
  58. <<" sex : "<<stu.sex()
  59. <<" age : "<<stu.age()<<endl;
  60. return os;
  61. }

main.cpp

  1. #include "Student.h"
  2. #include "RabbitMQ.h"
  3. #include <vector>
  4.  
  5. int main(int, char *[])
  6. {
  7.  
  8. Student s;
  9. cout<<s<<endl;
  10. s.id("SCP001");
  11. s.name("zhangsan");
  12. s.age(24);
  13. s.sex('M');
  14. cout<<s<<endl;
  15.  
  16. vector<string> stu_array;
  17. //for (int i=0;i<10;i++)
  18. //{
  19. // string string_stu(reinterpret_cast<const char*>(&s),reinterpret_cast<const char*>(&s) + sizeof(Student));
  20. // stu_array.push_back(string_stu);
  21. //}
  22.  
  23. CRabbitMQ pro;
  24. CExchange exchange("exchange");
  25. string queue_name("queue");
  26.  
  27. //mq::publish(stu_array,pro,exchange,queue_name);
  28. //cout<<"已经将students提交至MQserver"<<endl;
  29. stu_array.clear();
  30.  
  31. mq::consume(stu_array,pro,exchange,queue_name);
  32. cout<<"例如以下是从MQserver取回的Students"<<endl;
  33. for(int i=0;i<stu_array.size();i++)
  34. {
  35. Student* pstu = (Student*)stu_array[i].c_str() ;
  36. cout<<*pstu<<endl;
  37.  
  38. }
  39.  
  40. //char* ps = (char*)&s;
  41.  
  42. //string string_stu(reinterpret_cast<const char*>(&s),reinterpret_cast<const char*>(&s) + sizeof(Student));
  43.  
  44. //Student* pstu = (Student*)string_stu.c_str();
  45.  
  46. //cout<<*pstu<<endl;
  47. return 0;
  48. };

这里只展示了思路,详细的MQ封装是自己封装的和标准的MQ不太一样,封装版本号见:

http://blog.csdn.net/calmreason/article/details/23346397

使用RabbitMQ放置自己定义对象(不借助序列化工具,比如protobuffer)V2.0的更多相关文章

  1. js定义对象的几种容易犯的错误

    //js定义对象的几种容易犯的错误function Person() { getName = function (){ console.info(1); }; return this;}//Perso ...

  2. JavaScript学习12 JS中定义对象的几种方式

    JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...

  3. javascript 构造函数方式定义对象

    javascript是动态语言,可以在运行时给对象添加属性,也可以给对象删除(delete)属性 <html> <head> <script type="tex ...

  4. javaScript定义对象的方法

    转自souhu新闻http://news.sohu.com/20110215/n279335637.shtml? javascript定义对象的几种简单方法 1.构造函数方式,全部属性及对象的方法都放 ...

  5. JS笔记2 --定义对象

    16.javascript中定义对象的几种方式(javascript中没有类的概念,只有对象): 1)基于已有对象扩充其属性和方法: var object = new Object(); object ...

  6. switch case语句里面不能定义对象,有语法错误,除非加一个花括号

    最近发现一个问题呢 发现在switch的case里面不能去定义对象了,一定义对象就会报错了 仔细了解了一下在C或者C++中,只要是在任何一对花括号 “{ }”中定义的对象,那么该对象的作用域就局限在这 ...

  7. JavaScript学习12 JS中定义对象的几种方式【转】

    avaScript学习12 JS中定义对象的几种方式 转自:  http://www.cnblogs.com/mengdd/p/3697255.html JavaScript中没有类的概念,只有对象. ...

  8. (六)javascriptJS中定义对象的几种方式(转)

    JavaScript学习12 JS中定义对象的几种方式 转自:  http://www.cnblogs.com/mengdd/p/3697255.html JavaScript中没有类的概念,只有对象 ...

  9. JS中定义对象和集合

    在js中定义对象: 方式一: var obj = {}; obj['a']=1; obj['b']=2; 方式二: var obj=new Object(); obj.a=1; obj.b=2; 在j ...

随机推荐

  1. 命令行启动ubuntu

    图形模式下,首先进入终端: 1. 运行 sudo vi/etc/default/grub 2. 找到 GRUB_CMDLINE_LINUX_DEFAULT=”quiet splash” 3.改为 GR ...

  2. MyBatis动态条件、一对多、整合spring(二)

    输入映射和输出映射 Mapper.xml映射文件定义了操作数据库的sql,每一个sql是一个statement,映射文件是mybatis的核心. parameterType输入类型 1.传递简单类型 ...

  3. spring data jpa 、hibernate、jpa之间的关系

    引用:http://blog.csdn.net/u014421556/article/details/52635000 hibernate作为JPA的实现.   JPA规范与ORM框架之间的关系   ...

  4. js 全选选框与取消全选代码

    设置一个全选选框和四个子选框,要实现点击全选后四个子选框选中,取消全选后四个子选框也取消.全选后点击某个子选框,全选也能取消.当四个子选框都选中时,全选框也被选择. 实现代码: <script& ...

  5. SAP computer之program counter

    Program counter The program is stored in memory with the first instruction at binary address 0000, t ...

  6. 分布式机器学习框架:MxNet 前言

           原文连接:MxNet和Caffe之间有什么优缺点一.前言: Minerva: 高效灵活的并行深度学习引擎 不同于cxxnet追求极致速度和易用性,Minerva则提供了一个高效灵活的平台 ...

  7. (转)Arcgis for JS之地图自适应调整

    http://blog.csdn.net/gisshixisheng/article/details/42675897 概述:本节讲述的内容为当浏览器大小发生变化或者地图展示区域的大小发生变化时,地图 ...

  8. 利用node、express初始化项目

    前端做整站是开发,例如:前端是用了vue创建初始化项目,后端我们不会php.java等,我们只能用node去创建去做后端代码,本文就给大家讲解最基础的从零开始创建一个项目的后端环境. 一般来说前后端代 ...

  9. H5网页涂鸦canvas

    最近做了个播放页面,标题和一个iframe;需要对这个iframe可以进行网页涂鸦.网页涂鸦肯定是canvas了.网上找了个差不多的,实验下来问题很多,干脆自己一步步修改,学习. 效果: 本项目没有引 ...

  10. solr的学习

    1):  http://archive.apache.org/dist/lucene/solr/ref-guide/  pdf下载地址 solr历史版本的下载:http://archive.apach ...