Из какой памяти процессоры фактически читают данные?
В соответствии с моим собственным пониманием, для обработки данных ЦП они должны быть помещены в ОЗУ, в то же время сами ЦП имеют кэш-память, которая также используется для доступа к данным. Хорошо известен тот факт, что кэш процессора "ближе" к процессору и работает быстрее, чем любой другой тип памяти. Но для меня несколько неясно, обязательно ли для обработки данных находиться в кеше процессора? Если так, то как кеш может хранить большой объем данных? (размер кеша обычно крошечный, по сравнению с оперативной памятью, до нескольких мегабайт, чаще всего меньше 1). Если нет, то как процессор решает, какая часть данных должна храниться в его кеше?
Меня тоже немного смущает своп. Могут ли процессоры обрабатывать часть оперативной памяти и обращаться к хранящимся там данным непосредственно с жесткого диска?
1 ответ
Кэш на процессоре не хранит данные, он просто ускоряет доступ.
Основное объяснение кеша заключается в том, что когда ЦП идет на чтение определенного байта из ОЗУ, эти данные также копируются в кеш. В следующий раз, когда ЦП должен прочитать этот байт, контроллер памяти видит, что он находится в кеше, и вместо медленного обращения к ОЗУ он просто передает ЦП данные из кеша.
Есть два специфических вопроса с этим объяснением, хотя:
Кеш имеет конечный размер. Из-за этого, когда данные добавляются, вам в конечном итоге необходимо избавиться (или "отбросить") старые данные, чтобы освободить место для них. Есть несколько способов сделать это, и точная методология не имеет значения для этого обсуждения, но важно то, что через некоторое время данные могут больше не быть в кеше, и тогда вы должны выйти в основную память в любом случае.
Когда данные записываются, вам также необходимо обновить или удалить данные из кэша, которые ранее были сохранены по этому адресу. Есть три основных способа справиться с этим:
- Обратная запись: при использовании метода обратной записи данные сначала записываются в кэш, а затем в конечном итоге записываются в основную память. Это имеет ряд преимуществ для производительности, но может вызвать проблемы в некоторых обстоятельствах.
- Запись: используя метод записи, данные одновременно записываются как в кэш, так и в основную память. Это ниже, чем обратная запись, но безопаснее.
- Записывание: используя метод записи, данные записываются непосредственно в основную память, а затем данные, находящиеся в том же месте, удаляются из кэша. Это редко используется, за исключением очень конкретных случаев использования.
Итак, чтобы ответить на ваш вопрос относительно оперативной памяти в сравнении с кэшем ЦП, технически оба, но в конечном итоге данные поступают из оперативной памяти почти во всех случаях. Если вы хотите узнать больше об этом конкретно, я бы посоветовал прочитать следующие две статьи Википедии:
https://en.wikipedia.org/wiki/Cache_(computing)
https://en.wikipedia.org/wiki/CPU_cache
Теперь, что касается пространства подкачки, это совершенно другая концепция, связанная с виртуальной памятью и подкачкой. Попытка объяснить это привела бы к тому, что я написал бы большую часть пары статей Вкипедии, поэтому вместо этого я просто напишу вам прямо на эти статьи: