2017-02-26 80 views
2

我在C#中使用RX进行编程,现在我想用C++中的rxcpp进行编程。 我正在尝试做最简单的事情,定义一个类成员变量observable<int>
问题是,observable被定义为:rxcpp简单可观察<int>

template<class T, class SourceOperator> 
class observable 

什么是SourceOperator
如何定义简单的observable<int>

当寻找的代码,在RX-observable.hpp(线101):

template<class T, class Source> 
observable<T> make_observable_dynamic(Source&& s) { 
    return observable<T>(dynamic_observable<T>(std::forward<Source>(s))); 
} 

我发现observale<T>作为返回类型,但无法找到它的定义。
这太奇怪了。我虽然老实说我在C++ 11 \ 14 &元编程......显然兔子洞可以得到:-(

更新1更深的相当精通:
observale<T>已经发现:-) 其in rx-predef.hpp:

template<class T = void, 
     class SourceObservable = typename std::conditional<std::is_same<T,void>::value, 
      void, 
      dynamic_observable<T>>::type> 
class observable; 

ok我当前的猜测是dynamic_observable意味着“常规”observable<T>是一个动态的,类型为T的流。这是合乎逻辑的,因为您只能将类型擦除的流作为具有显式类型的变量来记录。
什么使我想到我的下一个猜测,即template<class T, class SourceOperator> class observable的语法使得能够在'decorator' pattern(编译时间修饰)中创建与其他可观察结合的可观察类型。类似例举here

+0

这很奇怪。 [github](https://github.com/Reactive-Extensions/RxCpp)页面上的示例定义了几个变量,但没有指定'SourceOperator':'observable '和'observable '。 – Rakete1111

+0

这个东西的文档真的很糟糕。 http://reactive-extensions.github.io/RxCpp/classrxcpp_1_1observable.html#details在整个地方使用'SourceOperator'而不解释它的含义。绝对不是我在私人玩具项目之外使用的东西。 –

+1

是的,更新1是正确的!在C++中,默认情况下让编译器看到完整的静态类型并将所有操作符合并在一起以获得性能。 SourceOperator是泛型observable类型所持有的observable的完整类型。 observable上的as_dynamic()方法将返回可擦除类型的可观察值,这将强制虚拟函数调用开销和缺省避免的堆分配开销。 –

回答

0

observale<T>已经发现:-) 其在RX-predef.hpp:

template<class T = void, 
     class SourceObservable = typename std::conditional<std::is_same<T,void>::value, 
      void, 
      dynamic_observable<T>>::type> 
class observable; 

dynamic_observableobservable<T>是T. 的动态的,类型ereased流它的逻辑,因为只能将类型擦除的流作为具有显式类型的变量来记录。
template<class T, class SourceOperator> class observable的语法允许在'decorator' pattern(编译时间装饰)中从其他可观察值组合的可观察类型的组合创建。例如here

相关问题