我正在编写一个小例子来尝试理解boost :: signal的多个返回值。然而,结果似乎对我有用。
#include <boost/signal.hpp>
#include <iostream>
#include <algorithm>
int func1()
{
return 3;
}
int func2()
{
return 4;
}
int func3()
{
return 2;
}
template <typename T>
struct min_element
{
typedef T result_type; //result_type is required by boost::signal
template <typename InputIterator>
T operator()(InputIterator first, InputIterator last) const
{
std::cout<<*std::min_element(first, last)<<std::endl; //I got 3 here
return T(first, last);
}
};
int _tmain(int argc, _TCHAR* argv[])
{
boost::signal<int (), min_element<std::vector<int> > > s;
s.connect(func1);
s.connect(func2);
s.connect(func3);
std::vector<int> v = s();
std::cout<<*std::min_element(v.begin(),v.end())<<std::endl; //I got 2 here
return 0;
}
第一个min_element输出“3”,而第二个输出“2”。显然,“2”是这三者中最小的数字。我不知道第一个有什么问题。在operator()中我也尝试从头到尾迭代,我得到序列“3,4,2”似乎是正确的。但是为什么min_element会给我“3”呢?
代码是使用VS2010 SP1编译的。 Boost的版本是1.46.1,这是最新版本。
提前致谢。
迈克尔
答案 0 :(得分:0)
怪异。替换operator()
:
T operator()(InputIterator first, InputIterator last) const
{
InputIterator result = first;
while (++first != last) {
// *result;
std::cout<<*first<<std::endl;
}
return T();
}
可以使用,但只要您取消引用result
,first
和result
就会陷入3.这就是std::min_element
正在做的事情;我找到了我的实现源代码,并将其删除为您在上面看到的内容。
我不知道发生了什么。
这是GCC 4.5.0上的Boost 1.38.0。