170 похожих чатов

Соратники, я тут что-то задумался. Вот в советах по оптимизации

всяких говорят мол у вектора лучше локальность Кеша потому что память для этой структуры это непрерывный блок в виде одной аллокации. Но локальность кеша это же чисто хардварный концепт , как и непрерывный блок памяти. К тому же процесс в юзерспейсе понятия не имеет о картине памяти в железе. То есть виртуальная память может и выглядеть непрерывной но физические маппинги могут отличаться. На сколько я понял у такой структуры лучше кеш локалити как раз из за хардварного механизма чтения памяти , что по факту получаем халявно следующую кеш линию если читаем последовательно . Вопрос является ли вектор физически непрерывным и если да то каким образом юзерспейс код stl может это имплементировать?

1 ответов

18 просмотров

Во-первых, все чтения из памяти происходят 64 байтными кусками, даже если вам нужен всего один байт. Поэтому, если мы сделали одно чтение из 64байтной кэш-линии, то следующие чтения из нее подряд будут стоить очень дёшево. Во-вторых, виртуальная память отображается в физическую непрерывными страницами по 4кб, и нужно постоянно по виртуальному адресу находить физический адрес в памяти. Если чтения происходят внутри страницы, то TLB cache позволит нам находить нужный физический адрес гораздо быстрее. В-третьих, процессору проще предугадать, что нам понадобится в будущем, если мы идём по адресам в понятном порядке, как разложены элементы в векторе. Наверняка, еще есть и в-четвертых, и в-пятых…

Похожие вопросы

Обсуждают сегодня

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
И никого не интересует какие пакеты кто использует. ((% Заходишь на сайт симфони и видишь поддержку Украины - по законам РФ это ж экстремизм. Только никто не отказывается от с...
Am Ambrion
11
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
7
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
14
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
Я правильно понимаю что нет способов получить список ожидающих заявок на вступление в группу с помощью бота из mtproto?
Шамиль Прилов
7
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Карта сайта