Понимание распределения памяти std :: queue и std :: priority_queueC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Понимание распределения памяти std :: queue и std :: priority_queue

Сообщение Anonymous »

Продолжение моего предыдущего вопроса: std :: Приоритет Итерация нескольких сотен микросекунд. Времени. Операция толчка обычно занимает около 5-25 микросекунд, но случайным образом занимает 300 микросекунд до 5 миллионов секунд. Память для моей std :: queue и std :: privetory_queue.

OS разработка: Ubuntu 24.04 lts.

my Target OS: vxworks 7

Язык: C ++ 17
< /p>
код: < /p>

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

struct DemoStruct
{
int a;
float b;
std::string data;
bool operator>(const DemoStruct& object) const //Check if greater
{
return this->a > object.a;
}
};

std::vector container;

std::priority_queue
<
DemoStruct,
std::vector,
std::greater
>
mReceiveDataQueue {
{}, std::move(this->container)
};

while (i < 10)
{
DemoStruct d = {
.a = 10 - i,
.b = i * 2.0f,
.data = "Hello, World!!!"; //Will mostly hold data with 85 characters
};
mReceiveDataQueue.push(d); //or mReceiveDataQueue.push(std::move(d))
}
< /code>
Что я хочу понять, поможет ли зарезервировать память? Из того, что я понимаю, каждый раз в конструкторе петли 
будет вызван и (пере) распределяет память. С схемами перемещения не будет ли компилятор просто переместить память на std :: priority_queue или std :: queue. Так полезно ли резервировать память вообще или она будет контрпродуктивной? Если я использую какую-то другую структуру данных, такую ​​как Boost :: Circular_queue Что было бы эффектом?

Подробнее здесь: https://stackoverflow.com/questions/794 ... rity-queue
Ответить

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

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

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

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

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