Будут ли компиляторы оптимизировать создание нового объекта в каждом цикле, если его размер останется прежним?C++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Будут ли компиляторы оптимизировать создание нового объекта в каждом цикле, если его размер останется прежним?

Сообщение Anonymous »

В некотором коде, который я написал, новый FenwickTree создается из векторного индекса, размер которого остается одинаковым в каждом цикле. Размер FenwickTree такой же, как и входной вектор. Не будет ли компилятор оптимизировать повторно в начале цикла, создавая объект и выделяя память, а затем уничтожая объект в конце цикла? Я больше знаком с C, где управление памятью является явным.
Пример

Код: Выделить всё

#include 
#include 

struct fenwick_tree
{
size_t len; // 0-based len
std::vector t; // 1-based tree, indexes [1:len]

fenwick_tree(std::vector const &a) :
len(a.size()), t(len + 1, 0)
{
for (size_t i = 0; i < len; ++i)
add_to(i, a[i]);
}

// 0-based input
int sum_to(size_t r) const
{
int s = 0;
for (++r; r > 0; r -= r & -r)
s += t[r];
return s;
}

// 0-based input
void add_to(size_t i, int delta)
{
for (++i; i 

Подробнее здесь: [url]https://stackoverflow.com/questions/79341481/will-compilers-optimize-constructing-a-new-object-every-loop-if-its-size-stays-t[/url]
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C++»