Я хочу предвосхитить этот ответ с отказом от ответственности - это предположение, поскольку я не выполнил код в вопросе и не рассмотрел фактическую реализацию библиотеки.Но я думаю, что это обрисовывает в общих чертах возможное объяснение любой статистически значимой разницы во времени, описанном в вопросе.Но имейте в виду, что является гипотезой на данный момент.
Разница во времени, необходимая для очистки вектора списков, может быть связана с тем, как кучаиспользуется и работа, которая может выполняться, когда куча обрабатывает элементы списка, которые освобождаются, когда списки уничтожаются.Я думаю, что может быть больше работы в куче, когда элементы списка освобождаются со вторым типом цикла.Я могу только догадываться (я не прошел через код библиотеки).
В первом стиле цикла каждый список получает один элемент, добавляемый за каждую итерацию цикла;другими словами, итерация цикла 0
помещает один элемент в каждый список, затем итерация цикла 1
добавляет другой элемент в каждый список и т. д.
Во втором примере (где операция clear()
занимает больше времени) каждый список создается отдельно;другими словами, список в ptrlistVector[0]
заполняется, затем ptrlistVector[1]
заполняется и т. д.
Я бы предположил, что для стиля первого цикла каждый элемент в определенном списке равен не подряд (в адресном пространстве) другим элементам в списке.Это произошло бы потому, что во время между любыми двумя push_back()
операциями в определенном списке происходило 50
других выделений для добавления элементов в другие списки.
Однако я бы предположил, что во втором стиле циклаэлементы в определенном списке более или менее последовательны, так как это порядок, в котором произошли распределения.
Теперь давайте подумаем, что это может означать, когда список уничтожается (как это произойдет, когда вектор, содержащий списки, будет очищен).Для списка, в котором элементы расположены последовательно в адресном пространстве, куча может тратить кучу времени на объединение этих смежных свободных блоков.Но когда список, имеющий группу элементов, которые не являются смежными, освобождает свои элементы, освобожденные блоки памяти не являются смежными, поэтому объединение не может произойти.До тех пор, пока мы не доберемся до последних (или последних нескольких) списков, куча начнет видеть соседние свободные блоки памяти, которые могут быть объединены.