bloomberg — в C ++ BLPAPI есть способ избежать использования hasElement или отлова ошибок

Обычно я делаю следующее:

if (msg.hasElement(BID_SIZE))
{
bid_sz=msg.getElementAsInt32(BID_SIZE);
}

Если я не использую проверку, сначала использую hasElement — тогда несуществующие поля выдают ошибку

2

Решение

Вместо того, чтобы использовать 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
}
1

Другие решения

Других решений пока нет …