Рассматривать vector как vector без копирования (C++0x)

Класс содержит std::vector<int*>. Внешнему коду нужен доступ -только для чтения к этому вектору, он не должен иметь возможности изменять содержимое (ни указателей, ни их содержимого ). Внутри класса значения могут измениться (, например. double_values(), поэтому сохранить их как std::vector<const int*>невозможно.

Есть ли способ вернуть std::vector<int*>как std::vector<const int*>без копирования? Кажется, что так и должно быть, потому что const просто работает во время компиляции, чтобы сказать, что можно и что нельзя изменить.

Код:(компилируется сg++ -std=c++0x)

class ReadOnlyAccess
{
public:
  ReadOnlyAccess(const std::vector<int*> & int_ptrs_param):
    int_ptrs(int_ptrs_param)
  {
  }
  const std::vector<int*> & get_int_ptrs() const
  {
    return int_ptrs;
  }
  std::vector<const int*> safely_get_int_ptrs() const
  {
    // will not compile (too bad):
    //    return int_ptrs;

    // need to copy entire vector
    std::vector<const int*> result(int_ptrs.size());
    for (int k=0; k<int_ptrs.size(); k++)
      result[k] = int_ptrs[k];
    return result;
  }
  void double_values()
  {
    for (int*p : int_ptrs)
      *p *= 2;
  }
  void print() const
  {
    for (const int * p : int_ptrs)
      std::cout << *p << " ";
    std::cout << std::endl;
  }
private:
  std::vector<int*> int_ptrs;
};

int main() {
  ReadOnlyAccess roa(std::vector<int*>{new int(10), new int(20), new int(100)});
  std::vector<const int*> safe_int_ptrs = roa.safely_get_int_ptrs();
  // does not compile (good)
  // *safe_int_ptrs[0] = -100000;
  roa.print();

  const std::vector<int*> & int_ptrs = roa.get_int_ptrs();
  // changes are made to the internal class values via the accessor! nooooo!
  *int_ptrs[0] = -100000;
  roa.print();

  return 0;
}
6
задан user 22 April 2012 в 06:19
поделиться