我在C#中用RX编程,现在我希望用c ++中的rxcpp编程。
我正在尝试做最简单的事情,定义observable<int>
的类成员变量
问题是observable
定义为:
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&amp;元编程......显然兔子洞可以变得更深: - (
更新1:
已发现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;
o.k。我目前的猜测是dynamic_observable
意味着'常规'observable<T>
是一个动态的,类型为基础的T流。
这是合乎逻辑的,因为你只能将类型擦除的流作为具有显式类型的变量
是什么让我接下来的猜测,template<class T, class SourceOperator> class observable
的语法允许从'decorator' pattern(编译时装饰)中的其他observable创建可观察类型。例如here
答案 0 :(得分:1)
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_observable
表示observable<T>
,它是一个动态的,基于类型的T流。
这是合乎逻辑的,因为你只能将类型擦除的流作为具有显式类型的变量
template<class T, class SourceOperator> class observable
的语法允许从'decorator' pattern(编译时装饰)中的其他observable创建可观察类型。例如here