oneway的定义和使用

问题现象:服务的定义,与面向对象技术中定义一个接口很类似,而这些接口其实就是纯虚函数。thrift编译工具会根据服务的定义来产生相应的方法和函数。每个服务,都包括了若干个函数,每个函数包括了若干个参数和一个返回值(返回值可以是void)。

问题改进:返回值为void的函数,你可以在函数名前加上oneway标识符,将此函数以异步模式执行,这样在调用此函数后,函数会立即返回。对于返回void的函数,thrift仍然会确保函数返回,这样表示这个函数被正确执行,且服务端已有返回信息了。但是如果给void的函数前加上oneway,那么此函数的返回只能表示数据已经进入传输层,并不能表示服务器端已经接收到并返回了数据。

问题总结:通过上面这段话,我们可以知道,oneway关键字使得函数在调用后只保证进入了传输层,之后的执行将不会被告知。而且上面括号中的话应该是错误的,不能说以异步模式执行,而且在进入传输层后新启动一个线程进行执行,当前线程直接返回。
总之:oneway不安全,但是效率高一些,在不要求一定要发送成功的情况下可以使用。

上一篇:mysql中加入海量数据


下一篇:c# – WPF:TwoWay绑定始终更新 – OneWay绑定仅在ONCE上更新