thrift小试--C++

【转自】http://blog.csdn.net/poechant/article/details/6618284#html

Thrift能够实现C++、JavaPython等多种语言的自动生成,此处以C++为例。java

1. 编写[.thrift]文件
python

将代码保存为student.thrift文件。apache

struct Student{  
 1: i32 sno,  
 2: string sname,  
 3: bool ssex,  
 4: i16 sage,  
}  

service Serv{  
 void put(1: Student s),  
} 

  

2. 自动生成服务器端程序bash

在Terminal中输入以下命令,可自动生成[.cpp]和[.h]文件。服务器

 

thrift -r --gen cpp student.thrift  socket

 

获得的文件以下:函数

 
  1. Serv.cpp  
  2. Serv.h  
  3. Serv_server.skeleton.cpp  
  4. student_constants.cpp  
  5. student_constants.h  
  6. student_types.cpp  
  7. student_types.h  

其中Serv_server.skeleton.cpp中有服务器端运行的main函数。这些文件名的Serv和student与你最初建立的thrift文件有关。spa

 

3. 编写客户端程序.net

#include "Serv.h"  // Your .h File  
#include <transport/TSocket.h>  
#include <transport/TBufferTransports.h>  
#include <protocol/TBinaryProtocol.h>  

using namespace apache::thrift;  
using namespace apache::thrift::protocol;  
using namespace apache::thrift::transport;  
using boost::shared_ptr;  

int main(int argc, char **argv) {  

     boost::shared_ptr<TSocket> socket(new TSocket("localhost", 9090));  
     boost::shared_ptr<TTransport> transport(new TBufferedTransport(socket));  
     boost::shared_ptr<TProtocol> protocol(new TBinaryProtocol(transport));  

     ::SS::Student stu;
     ::SS::ServClient sn(protocol);
     transport->open();
     sn.put(stu);
     transport->close();  
     return 0;  

} 

  

 

4. 编译/连接

g++ -g -I/usr/include/thrift -L/usr/lib/ -lthrift -DHAVE_INTTYPES_H -DHAVE_NETINET_IN_H  Serv.cpp student_types.cpp student_constants.cpp Serv_server.skeleton.cpp -o server

g++ -g -I/usr/include/thrift -L/usrlib/ -lthrift -lm -pthread -lz -lrt -lssl -DHAVE_INTTYPES_H -DHAVE_NETINET_IN_H Serv.cpp student_types.cpp student_constants.cpp client.cpp -o client

  

5. 运行

 

./server  

./client  

相关文章
相关标签/搜索