Следующий код демонстрирует синтаксис для использования неявных преобразований и копирования любых объектов:
#include <list>
#include <boost/any.hpp>
using boost::any_cast
;
typedef std::list<boost::any
> many;
void append_int(many & values, int value)
{
boost::any
to_append = value;
values.push_back(to_append);
}
void append_string(many & values, const std::string & value)
{
values.push_back(value);
}
void append_char_ptr(many & values, const char * value)
{
values.push_back(value);
}
void append_any(many & values, const boost::any
& value)
{
values.push_back(value);
}
void append_nothing(many & values)
{
values.push_back(boost::any
());
}
Следующие предикаты следуют из предыдущих определений и демонстрируют использование запросов на любых объектах:
bool is_empty(const boost::any
& operand)
{
return operand.empty
();
}
bool is_int(const boost::any
& operand)
{
return operand.type
() == typeid(int);
}
bool is_char_ptr(const boost::any
& operand)
{
try
{
any_cast
<const char *>(operand);
return true;
}
catch(const boost::bad_any_cast
&)
{
return false;
}
}
bool is_string(const boost::any
& operand)
{
return any_cast
<std::string>(&operand);
}
void count_all(many & values, std::ostream & out)
{
out << "#empty == "
<< std::count_if(values.begin(), values.end(), is_empty) << std::endl;
out << "#int == "
<< std::count_if(values.begin(), values.end(), is_int) << std::endl;
out << "#const char * == "
<< std::count_if(values.begin(), values.end(), is_char_ptr) << std::endl;
out << "#string == "
<< std::count_if(values.begin(), values.end(), is_string) << std::endl;
}
Следующий тип, созданный по образцу Службы собственности OMG, определяет пары именных значений для произвольных типов значений:
struct property
{
property();
property(const std::string &, const boost::any
&);
std::string name;
boost::any
value;
};
typedef std::list<property> properties;
Следующий базовый класс демонстрирует один подход к обратному вызову на основе полиморфизма во время выполнения, который также требует произвольных типов аргументов. Отсутствие шаблонов виртуальных членов требует, чтобы разные решения имели разные компромиссы с точки зрения эффективности, безопасности и универсальности. Использование проверенного типа варианта предлагает один подход:
class consumer
{
public:
virtual void notify(const any
&) = 0;
...
};