Получение значения из двумерного Safearray в C ++ - PullRequest
3 голосов
/ 29 июля 2010

Я относительно новичок в мире C ++.Я хочу получить доступ к данным из многомерного SAFEARRAY.Однако, когда я пытаюсь получить значение, я получаю сообщение об ошибке 0xC0000005: Место чтения нарушения доступа 0x40e3e300.Приложенный ниже мой код и отмеченная строка, где это ошибки.Надеюсь, кто-то может пролить свет на то, как решить эту проблему.

 SAFEARRAY *ArrayCrosstabInfo = GetMainFrame().m_epsComHelper->GetCrosstab(m_arrayFieldnames,start,end);
  COleSafeArray ArrayCrosstab(*ArrayCrosstabInfo,VT_SAFEARRAY);

  BSTR *DataValue;
  ArrayCrosstab.AccessData((void**) &DataValue);

  long lUBoundX;
  long lUBoundY;

  ArrayCrosstab.GetUBound(1,&lUBoundX);
  ArrayCrosstab.GetUBound(2,&lUBoundY);

  long lOffset = 2;
  int nFieldIndex = 0;

  if (lUBoundX > 0 && lUBoundY > 0)
  {
    //only interested in DataValue[0,x]
    for (long i = lOffset; i<=lUBoundY; i++)
    {
      _bstr_t theData((BSTR)DataValue[0,i],FALSE); <==ERRORS HERE
     //Display (BSTR)theData;
    }
  }

Ответы [ 2 ]

2 голосов
/ 30 июля 2010

Ребята, удалось это решить.Ничего особенного, но вот оно.

 SAFEARRAY *ArrayCrosstabInfo = GetMainFrame().m_epsComHelper->GetCrosstab(m_arrayFieldnames,start,end);

  int lOffset = 2;
  long index[2];

  long lUBoundX;
  long lUBoundY;

  SafeArrayGetUBound(ArrayCrosstabInfo, 1, &lUBoundX);
  SafeArrayGetUBound(ArrayCrosstabInfo, 2, &lUBoundY);

  if (lUBoundX >= 0 && lUBoundY >= 0)
  {
    double theResult = 0;
    for (long i=lOffset; i<=lUBoundY; i++)
    {
     index[0] = 0;
     index[1] = i;

     SafeArrayGetElement(ArrayCrosstabInfo, index, &theResult);

     std::ostringstream strs;
     strs << theResult;
     std::string str = strs.str();
     CString cs(str.c_str());
     //display cs
    }
  }
1 голос
/ 29 июля 2010

Ваше индексирование не соответствует этой строке:

_bstr_t theData((BSTR)DataValue[0,i],FALSE);

В C ++ двумерные массивы индексируются как массив [x] [y].Кроме того, индексирование начинается с 0, поэтому вам, вероятно, нужно исправить ошибочную строку на что-то вроде

_bstr_t theData((BSTR)DataValue[0][i-1],FALSE);
...