Thrift类型

Thrift类型系统旨在允许程序员尽可能使用本机类型,无论使用何种编程语言。此信息基于并取代Thrift白皮书中的信息。Thrift IDL为每一种目标语言提供了用于生成代码的类型描述。

基本类型

基本类型是侧重于所有编程语言可用的关键类型:

bool:一个布尔值(true或false)

byte:一个8位有符号整数

i16:一个16位有符号整数

i32:一个32位有符号整数

i64:一个64位有符号整数

double:一个64位浮点数

string:使用UTF-8编码的文本字符串

特殊类型

binary:未编码的字节流。

注意:这是目前上述字符串类型的一种特殊形式,用于提供与Java更好的互操作性。目前的记录计划在某种程度上将其提升为基本类型。

结构体

Thrift结构体定义了一个通用对象,它们基本等同于OOP语言中的类,但是没有继承。结构体具有一组强类型字段,每个字段都具有唯一的名称标识符。字段可能具有Thrift IDL中描述的各种注释(数字字段ID,可选的默认值等) 。

struct Example {
1:i32 number = 0,
2:i64 bigNumber,
3:double decimals,
4:string name = "thrifty"
}

字段有optional和required之分,如果不指定则默认为required。其中required是必填字段,optional是可选字段,非必填的。而且每个字段可以设置默认值 。

struct Example {
1: required i32 number = 0,
2:optional i64 bigNumber,
3:double decimals,
4:string name = "thrifty"
}

容器

Thrift容器是强类型的容器,映射到大多数编程语言中常用的容器类型。

Thrift有三种容器:

list:一个有序的元素列表,转换成STL vector,Java ArrayList,脚本语言的native数组。

set:一个无序的元素集合,所有元素都是唯一的。转换成STL set,Java HashSet,Python的set等,PHP不支持set,所以它被视为类似于List。

map:一个严格唯一的键值映射。转换成STL map,Java HashMap,PHP关联数组,Python/Ruby字典等。虽然提供了默认值,但类型映射并未明确固定。已添加自定义代码生成器指令以允许用各种目标语言替换自定义类型。

容器元素可以是任何有效的Thrift类型。

注意:为了达到最大的兼容性,map的键类型应该是基本类型,而不是结构体或容器类型。有一些语言本机map类型不支持更复杂的键类型。另外,Json协议仅支持基本类型的键类型。

struct Example {
1:i32 number = 0,
2:i64 bigNumber,
3:double decimals,
4:string name = "thrifty",
5:map<string, string> idMap,
6:list<string> telphoneNumbers,
7:set<i32>
testSet
}

异常

异常在功能上等同于结构体,除了它们在每种目标编程语言中适当地继承本机异常基类以便与任何给定语言中的本机异常处理无缝集成之外。

exception TException {
1: i32 errCode,
2: string msg
}

枚举

1.编译器默认从0开始赋值 
2.可以赋予某个常量某个整数 
3.允许常量是十六进制整数 
4.末尾没有分号 
5.给常量赋缺省值时,使用常量的全称

enum TResult {
SUCCEED = 0,
FAILED = 1
}

常量定义

在变量前面加上const

const i32 SUCCEED = 0;

服务

服务使用Thrift类型进行定义。服务的定义在语义上等同于定义面向对象编程中的接口(或纯虚拟抽象类)。Thrift编译器生成实现该接口的功能齐全的客户端和服务器原型。

服务由一组命名函数组成,每个函数都有一个参数列表和一个返回类型。

请注意,除了所有其他定义的Thrift类型之外,void是函数返回的有效类型。此外,单向修饰符关键字可以添加到void函数中,该函数将生成不等待响应的代码。请注意,纯粹的void函数会向客户端返回一个响应,以确保操作在服务器端完成。使用单向方法调用客户端将只能保证请求在传输层成功。服务器可以并行/不按顺序执行同一客户端的单向方法调用。

service StringCache {
void setNode(1:i32 key, 2:string value),
string getNode(1:i32 key) throws(1:TException exp),
void delNode(1:i32 key)
}

Include

一个包含所有来自另一个文件的符号可见(带有前缀),并将相应的包含语句添加到为此Thrift文档生成的代码中。该特性可以清晰地管理代码模块。

include "example.thrift"
service StringTest {
void sayHello()throws(1:example.TException exp)
}

命名空间

Thrift中的命名空间类似于C++中的namespace和java中的package,它们提供了一种组织(隔离)代码的简便方式。命名空间也可以用于解决类型定义中的名字冲突。

namespace java thrift.test
namespace cpp thrift.test

注释

支持Java多行和单行注释风格。

/**
* Program doctext.
* Seriously, this is the documentation for this whole program.
*/ // this is a test

Thrift IDL的更多相关文章

  1. Thrift IDL使用方式

    I.背景 众所周知,Thrift是一个RPC的框架,其可用于不同语言之间的服务相互调用.比如最近接触到的一个运用环境: *前端使用Node.Js重构了部分我们的老旧代码(前后端未分离的SpringBo ...

  2. 环境初始化 Build and Install the Apache Thrift IDL Compiler Install the Platform Development Tools

    Apache Thrift - Centos 6.5 Install http://thrift.apache.org/docs/install/centos Building Apache Thri ...

  3. Thrift IDL基本语法

    简言:介绍Thrift的IDL基本语法,初次使用或多或少的会有很有"坑"要踩,但是我们要遇山挖山,遇海填海,在学习的道路上坚定的走下去,方可日后吹牛B! IDL Thrift 采用 ...

  4. thrift:swift项目笔记

    先声明:此swift不是Apple公司的那个swift开发语言,而是facebook的另一个开源项目. facebook的thrift IDL文件,如果默认用thrift -gen java生成jav ...

  5. Thrift:Quick Start

    Thrift 快速开始 1 Thrift 介绍 目前流行的服务调用方式有很多种,例如基于 SOAP 消息格式的 Web Service,基于 JSON 消息格式的 RESTful 服务等.其中所用到的 ...

  6. thrift 一个有意思的特性:Class名称无关性

    最近开发的一个项目,后端采用thrift框架来提供rpc服务(java语言实现),然后前端采用php语言来生成thrift client调用后台RPC服务.由于某些原因,上周我把thrift定义文件中 ...

  7. Apache Avro 与 Thrift 比较

    http://www.tbdata.org/archives/1307 Avro和Thrift都是跨语言,基于二进制的高性能的通讯中间件. 它们都提供了数据序列化的功能和RPC服务. 总体功能上类似, ...

  8. [转] thrift的使用介绍

    http://gemantic.iteye.com/blog/1199214 一.About  thrift   二.什么是thrift,怎么工作? 三.Thrift  IDL 四.Thrift   ...

  9. Apache Thrift的简单使用

    Apache Thrift的简单使用 ---------------------- 1. 简介 Thrift是Facebook的一个开源项目,主要是一个跨语言的服务开发框架.它有一个代码生成器来对它所 ...

随机推荐

  1. 【T01】理解面向连接和无连接协议之间的区别

    1.面向连接和无连接指的是协议,本质区别在于:对于无连接协议来说,每个分组的处理都独立于其他的分组. 而对于面向连接的协议,协议实现维护了当前分组与后继分组有关的状态信息. 2.无连接就是指udp,分 ...

  2. Window下对nodejs多版本管理GNVM

    Windows下对nodejs多版本的管理,实现随意切换! 官方地址: https://github.com/Kenshin/gnvm http://ksria.com/gnvm/ 01.下载GNVM ...

  3. iPhone X 适配 ( iOS 11适配 )

    总结: 1.状态栏高度发生变化,解决方案:布局的时候这个高度不要写死,通过方法获取高度. 2.导航栏的视图层级结构发生变化而导致 UI(titleView.UIBarButtonItem) 问题. 3 ...

  4. 基于CentOS体验万象优图鉴黄服务

    系统要求:CentOS 7.2 64 位操作系统 初始化配置 使用万象优图图片鉴黄 API 接口,我们需要先完成以下步骤: 获取腾讯云账号 APP ID 配置云 API 公钥/密钥 配置优图 buck ...

  5. php http请求封装

    /** * 发送HTTP请求方法,目前只支持CURL发送请求 * @param string $url 请求URL * @param array $params 请求参数 * @param strin ...

  6. springboot集成redis缓存

    1.pom.xml增加redis缓存起步依赖(spring-boot-starter-parent包含许多starter版本) <dependency> <groupId>or ...

  7. 升级python(linux)

    查看系统当前python版本 2: [root@wangyuelou ~]# python     Python 2.4.3 (#1, May  5 2011, 16:39:10)     [GCC ...

  8. Java 汇编代码

    https://shipilev.net/blog/2015/black-magic-method-dispatch/ https://github.com/shipilev/article-meth ...

  9. windows下安装pycharm并连接Linux的python环境

    1. 下载安装Pycharm专业版 具体方法略.Pycharm5激活方法参考http://www.cnblogs.com/snsdzjlz320/p/7110186.html 2. 添加配置连接远程服 ...

  10. github desktop的使用

    1.建仓库 2.添加文件 3.提交文件到本地仓库 4.撤销提交到本地仓库 或者直接Ctrl+Z 5.提交到远端仓库 6.添加一个分支 7.分支合并 1.本地仓库合并 将新分支添加的文件合并到maste ...