Обычно я делаю следующее:
if (msg.hasElement(BID_SIZE))
{
bid_sz=msg.getElementAsInt32(BID_SIZE);
}
Если я не использую проверку, сначала использую hasElement — тогда несуществующие поля выдают ошибку
Вместо того, чтобы использовать getElementAsInt32
использование getValueAs
:
Element field;
int err=msg.asElement().getElement(&field, BID_SIZE);
if (!err)
{
int valerr=field.getValueAs(&bid_sz); // will call getValueAs for the type of bid
}
Это позволит избежать поиска BID_SIZE дважды в сообщении и не будет выдавать, когда поля не найдены.
В качестве альтернативы вы можете просмотреть все поля и проверить, какое это поле:
Element asElem=msg.asElement();
size_t num=asElem.numElements();
for (size_t i=0; i < num; ++i)
{
Element field=asElem.getElement(i);
Name field_name=field.name();
if (field_name == BID_SIZE)
{
bid_sz=field.getValueAsInt32();
}
// check other fields
// put more likely fields at the top
}
Других решений пока нет …