Как исправить странные коды C++, которые предполагают относительный порядок членов класса

Мне нужно изменить порядок членов моего класса C++. Например:

class B {
public:
int i;
int j;
int k;
...
};

становится

class B {
public:
int j;
int k;
int i;
...
};

Проблема в том, что в моих больших кодовых базах есть странные коды, которые зависят от относительного расположения членов класса. Например, некоторые функции предполагают, что адрес члена j меньше адреса члена k.

Есть ли какой-нибудь инструмент CASE, который может помочь мне идентифицировать любой код, который читает адрес члена класса?

1 ответ

Я не знаю ни одного инструмента, который решит вашу проблему, но я бы определил класс, который поддерживает все операторы для int тип и который перегружает оператор амперсанда, так что результат оператора не может быть приведен к указателю. Тогда я бы использовал этот класс вместо int в определениях членов вашего класса и посмотрите на места, где компилятор дает ошибки.

Что-то вроде

class IntWrapper {
 public:
  IntWrapper() { }
  IntWrapper(const int x) { }         // don't care about implementation as we 
  operator int() const { return 0; }  // want compile-time errors only
  IntWrapper& operator ++() { return *this; }
  IntWrapper& operator ++(int) { return *this; }

  ...
  void operator &() const { } // make it void so it would cause compiler error
};

А потом:

class B {
 public:
  IntWrapper i;
  IntWrapper j;
  IntWrapper k;
 ...
};

Это не поможет против использования boost::addressof функция или какая-то грязная reinterpret_cast ссылки, но addressof вероятно, никогда не используется в вашем проекте, а также reinterpret_cast<char&> трюк (кто бы использовал его для простых целых чисел?).

Вы также должны позаботиться о том, чтобы взять адрес всего объекта B учебный класс.

Другие вопросы по тегам