Можно ли уничтожить объект раньше, чтобы его память использовалась последующими объектами?

C++: можно ли уничтожить объект раньше, чтобы его память использовалась последующими объектами?

В одном сегменте кода C++ в первой половине используются объекты a, b; во второй половине части объекты c, d создаются и используются.

Поскольку объекты a, b занимают много памяти, я хочу вручную уничтожить объекты a, b, когда закончится 1-я половина.

Я знаю, что могу использовать новое, удалить, чтобы добиться этого.

Но если я не использую новый и все еще хочу уничтожать объекты раньше (это означает, что до момента его окончания области действия), могу ли я вручную вызвать его деструктор, чтобы уничтожить его? Так что эта часть памяти может быть повторно использована для объектов c и d. (Мне не нужно освобождать память, так как повторное использование в порядке.

Вот псевдокод:

monsterClass a, b;
dragonClass c, d;
int i,j,k,l;

a = monsterClass(1000, 2000);
b = monsterClass(2000, 3000);
i = processMethod1(a, b);
j = ...;
k = ...;
l = ...;


// here, I want to destroy a, b, since they are not used any more, while occupy memory.
// The above half part and the below half part use many common variables. 
// So it seems scope {} method makes it inconvenient, 
// since I don't want to create a function with too many parameters.
// I don't want to use new or delete here. I hope it looks simple and not prone to error
// So can I use: ~a, ~b here?

c = dragonClass(400, 3000);
d = dragonClass(500, 4000);
processMethod2(c, d, i);
j = ...;
k = ...;
l = ...;

[Обновление 1] Так что большинство людей предлагают использовать сферу, что является хорошим способом. Мне просто все еще очень любопытно, могу ли я использовать ~a и ~b там? Я думаю, что это кажется возможным и удобным способом тоже.

[Обновление 2] У меня возникла другая ситуация. В этой ситуации границы различных переменных переплетаются! Это так: область действия a перекрывается с областью действия b, но они не включают отношения. Это частичное совпадение отношений. В этом случае означает ли это, что использование области невозможно? И последнее средство - использовать новое и удалить, верно?

4 ответа

Используйте размещение new и вызовите деструкторы вручную:

{
  char memory[std::max(sizeof(A),sizeof(B))];

  A* pA = new (memory) A();
  // use `pA`
  pA->~A(); // destruct A

  B* pB = new (memory) B();
  // use `pB`
  pB->~B(); // destruct B
} // `memory` goes out of scope

Я рекомендую прочитать этот отличный ресурс по новому оператору: http://en.cppreference.com/w/cpp/language/new

Вы можете разбить его на более мелкие функции:

void part1() {
    monsterClass a, b;
    a = monsterClass(1000, 2000);
    b = monsterClass(2000, 3000);

    processMethod1(a, b);
}

или блоки в большей функции

{
    monsterClass a, b;
    // and so on
}
{
    dragonClass c, d;
    // and so on
}

или использовать временные

processMethod1(
    monsterClass(1000, 2000);
    monsterClass(2000, 3000);
);

Если вы делаете что-то настолько сложное, что ни один из них не подходит, вы можете возиться с объединением или новым размещением; детали будут сложными, в зависимости от ваших странных требований.

Как ваш фрагмент кода, вы можете написать как

int i,j,k,l;

{
  monsterClass a(1000, 2000);
  monsterClass b(2000, 3000);
  i = processMethod1(a, b);
  j = ...;
  k = ...;
  l = ...;
}

// here, you want to destroy a, b, since they are not used any more, while occupy memory.

dragonClass c(400, 3000);
dragonClass d(500, 4000);
processMethod2(c, d, i);
j = ...;
k = ...;
l = ...;

// you could use the same technique if there are still e, f or so

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

void foo()
{
    int x = 5;
    int y = 2;

    {          // This introduces a new scope
    int z = 3;
    }          // After this brace, z is now out of scope

    int a = x + y;
}

Но учтите, что как только переменная выходит из области видимости, при повторном использовании этой памяти не указывается. Просто потому, что я объявил другой int названный a, не означает, что ему будет назначен адрес, на котором z раньше был.

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