我使用容器来保存指针列表任何东西:比较的boost ::任何内容
struct Example {
std::vector<boost::any> elements;
}
插入在这个容器中的元素,我写了几个辅助功能(该struct Example
成员):
void add_any(boost::any& a) {
elements.push_back(a);
}
template<typename T>
void add_to_list(T& a) {
boost::any bany = &a;
add_any(bany);
}
现在,我只想插入元素时,他们不存在于此容器中。为了做到这一点,我认为我只需要在elements
之上调用search
以及适当的比较器功能。但是,我不知道如何比较boost::any
实例。
我的问题: 知道我的boost::any
实例总是包含指向某物的指针;有可能比较两个boost::any
值吗?
更新
我感谢你的答案。我也设法做到这一点可能不安全的方式:使用boost::unsafe_any_cast
获得void**
并比较底层的指针。
目前,这工作正常。不过,我会欣赏你的评论:也许这是一个很大的错误!
#include <boost/any.hpp>
#include <iostream>
#include <vector>
#include <string>
using namespace std;
bool any_compare(const boost::any& a1, const boost::any& a2) {
cout << "compare " << *boost::unsafe_any_cast<void*>(&a1)
<< " with: " << *boost::unsafe_any_cast<void*>(&a2);
return (*boost::unsafe_any_cast<void*>(&a1)) ==
(*boost::unsafe_any_cast<void*>(&a2));
}
struct A {};
class Example {
public:
Example() : elements(0),
m_1(3.14),
m_2(42),
m_3("hello"),
m_4() {};
virtual ~Example() {};
void test_insert() {
add_to_list(m_1);
add_to_list(m_2);
add_to_list(m_3);
add_to_list(m_4);
add_to_list(m_1); // should not insert
add_to_list(m_2); // should not insert
add_to_list(m_3); // should not insert
add_to_list(m_4); // should not insert
};
template <typename T>
void add_to_list(T& a) {
boost::any bany = &a;
add_any(bany);
}
private:
vector<boost::any> elements;
double m_1;
int m_2;
string m_3;
A m_4;
void add_any(const boost::any& a) {
cout << "Trying to insert " << (*boost::unsafe_any_cast<void*>(&a)) << endl;
vector<boost::any>::const_iterator it;
for (it = elements.begin();
it != elements.end();
++it) {
if (any_compare(a,*it)) {
cout << " : not inserting, already in list" << endl;
return;
}
cout << endl;
}
cout << "Inserting " << (*boost::unsafe_any_cast<void*>(&a)) << endl;
elements.push_back(a);
};
};
int main(int argc, char *argv[]) {
Example ex;
ex.test_insert();
unsigned char c;
ex.add_to_list(c);
ex.add_to_list(c); // should not insert
return 0;
}
备注:你的'add_any'和'add_to_list'函数应该以const-reference作为参数。另外,如果你想要唯一性,你可以考虑使用'set'而不是'vector'。当然,你仍然需要比较功能。 – 2011-05-17 09:53:53
好问题。这可能是不可能的。然而,如果你愿意实现*你自己*任何,有办法做到这一点(如果基础类型都相同,但不支持比较语义)*运行时失败* – 2011-05-17 10:23:49
你确定你想将参数的地址存储到'add_to_list'帮助器中?请注意'boost :: any'会复制对象,但在这种情况下,对象是一个指针。 – 2011-05-17 10:59:36