Зависит от того, что вы malloc()
.Если вы используете malloc()
для больших порций данных, это не должно иметь реальных различий.Но если вы malloc()
элементов меньше 64 байт, вы, вероятно, не будете эффективно использовать кэш.
malloc()
выделяет элементы в памяти в порядке программы.Если несколько malloc()
близки, элементы будут находиться в последовательных адресах памяти, и вполне вероятно, что они будут использоваться вместе, поскольку они были созданы одновременно.Это так называемый принцип пространственной локализации .Конечно, ничего не гарантируется, особенно с динамически распределяемыми данными, но пространственная локальность наблюдается в большинстве программ.Практическое значение этого принципа состоит в том, что он позволяет лучше использовать кэши.Отсутствие кэша обходится дорого (нужно извлечь 64 байта из памяти), но если вы используете элементы, закрывающиеся в памяти, вы должны заплатить это только один раз.
Таким образом, если отдельно выделенные данные находятся в одном и том же месте.Строка кэша, выбирая один из этих элементов, позволит вам бесплатно закрыть другие элементы в памяти.Но если каждый элемент занимает всю строку кэша, как и в случае с вашим модифицированным распределителем, это уже не так.Каждый доступ к данным будет являться пропуском кеша, количество данных, которые может хранить ваш кеш, будет уменьшаться, и у вас будет впечатление, что размер кеша уменьшается.Грубым результатом будет увеличение времени вычислений.