Variantにfloat値があります。最初、このバリアントはbstrタイプです。VariantChangeTypeを使用してfloatタイプに変更しています。それから私はそれからfloat値を取得し、それから私はバイトベクトル形式に変換しています。
バリアントにfloat値がある場合、これは正常に機能します。バリアントにINF値がある場合、VariantChangeTypeは失敗します。だから私はvariant.fltValから0を取得しています。
バリアントがINFまたはNAN値を持つ場合、タイプをフロートに変更するにはどうすればよいですか?floatでINFまたはNAN値を取得したい。
Convert(_variant_t varVal,vector<byte> dataArr)
{
HRESULT hr = VariantChangeType( varVal&, &varVal, 0 , VT_R4 );
// Above code is failing if varVal.bstr contains 1.#INF" values
UINT size = 4;
if ( data && dataItem.vt != VT_EMPTY )
{
float value = dataItem.fltVal;
BYTE tmpBuf[4];
memcpy(tmpBuf, &value, sizeof(value));
for( int i = size - 1 ; i >= 0 ; i-- )
{
data->push_back(tmpBuf[i]);
}
retVal = TRUE;
}
}