Лингвистика

Переведите текст или найдите его перевод

Cache Memory

Most PCs are held back not by the speed of their main processor, but by the time it takes to move data in and out of memory. One of the most important techniques for getting around this bottleneck is the memory cache.

The idea is to use a small number of very fast memory chips as a buffer or cache between main memory and the processor. Whenever the processor needs to read data it looks in this cache area first. If it finds the data in the cache then this counts as a 'cache hit' and the processor need not go through the more laborious process of reading data from the main memory. Only if the data is not in the cache does it need to access main memory, but in the process it copies whatever it finds into the cache so that it is there ready for the next time it is needed. The whole process is controlled by a group of logic circuits called the cache controller.

One of the cache controller's main jobs is to look after 'cache coherency' which means ensuring that any changes written to main memory are reflected within the cache and vice versa. There are several techniques for achieving this, the most obvious being for the processor to write directly to both the cache and main memory at the same time. This is known as a “write-through” cache and is the safest solution, but also the slowest.

The main alternative is the “write-back” cache which allows the processor to write changes only to the cache and not to main memory. Cache entries that have changed are flagged as 'dirty', telling the cache controller to write their contents back to main memory before using the space to cache new data. A write-back cache speeds up the write process, but does require a more intelligent cache controller.

Most cache controllers move a 'line' of data rather than just a single item each time they need to transfer data between main memory and the cache. This tends to improve the chance of a cache hit as most programs spend their time stepping through instructions stored sequentially in memory, rather than jumping about from one area to another. The amount of data transferred each time is known as the 'line size'.

How a Disk Cache Works

Disk caching works in essentially the same way whether you have a cache on your disk controller or you are using a software-based solution. The CPU requests specific data from the cache. In some cases, the information will already be there and the request can be met without accessing the hard disk.

If the requested information isn't in the cache, the data is read from the disk along with a large chunk of adjacent information. The cache then makes room for the new data by replacing old. Depending on the algorithm that is being applied, this may be the information that has been in the cache the longest, or the information that is the least recently used. The CPU's request can then be met, and the cache already has the adjacent data loaded in anticipation of that information being requested next.
Кэш-память Большинство ПК сдерживает не скорость их основной процессор, но и время, необходимое для перемещения данных в и из памяти. Одним из наиболее важных методов для получения вокруг этой проблемы является кэш-памяти. Идея состоит в использовании небольшого количества очень быстрых чипов памяти, как буфер или кэш между основной памятью и процессором. Всякий раз, когда процессор должен читать данные, которые он смотрит в эту область кэша в первую очередь. Если он находит данных в кэше, то это считается как "попадания в кэш" и процессор не нужно идти через более трудоемкий процесс чтения данных из основной памяти. Только если данные не в кэше, нуждается ли она для доступа к основной памяти, но в процессе она копирует все, что находится в кэш, так что там готовы в следующий раз это необходимо. Весь процесс находится под контролем группы логических схем называют кэш контроллера. Одной из главных рабочих мест кэша контроллера в том, чтобы заботиться о 'когерентности кэша ", что означает обеспечение того, чтобы любые изменения записываются в основную память, отражаются в кэше, и наоборот. Есть несколько методов для достижения этого, наиболее очевидные из которых для процессора писать прямо как кэш-памяти и основной памяти, в то же время. Это известно как "сквозной записью" кэш-памяти и является наиболее безопасным решением, но и самый медленный. главной альтернативой является "обратной записи" кэша, который позволяет процессору записать изменения только в кэш, а не в основную память. Кэш записи, которые были изменены помечаются как "грязные", рассказывая кэша контроллера, чтобы написать их содержимое обратно в основную память, прежде чем использовать пространство для кэширования новых данных. Запись в кэш ускоряет процесс записи, но требует более интеллектуальных кэша контроллера. Большинство контроллеров кэш двигаться «линии» данных, а не только одного элемента каждый раз, когда требуется для передачи данных между основной памятью и кэш-памяти. Это приводит к улучшению шансов попадания в кэш, поскольку большинство программ тратят свое время пошагового инструкции, хранящиеся в памяти последовательно, а не прыгать о из одного района в другой. Объем данных, передаваемых каждый раз известен как "размер строки. Как дискового кэша Работы работ кэширование диска в основном так же, есть ли у вас кэш на диске контроллера или вы используете программное решение. Процессор запросов конкретных данных из кэша. В некоторых случаях информация уже будет там, и запрос может быть удовлетворен без доступа к жесткому диску. Если запрашиваемая информация не находится в кэше, данные считываются с диска, а также большой кусок смежных информации. Кэше, то создает место для новых данных, заменив старые. В зависимости от алгоритма, который применяется, это может быть информация, которая была в кэше самый длинный, или информацию, которая является наименее недавно использовали. Запрос процессора могут быть выполнены, и уже имеет кэш смежных данных, загруженных в ожидании, что информация запрашивается следующий.
Adrinalina Zimmerman
Adrinalina Zimmerman
747
Лучший ответ
Кэш-память

Большинство PC сдержано не скоростью их главного процессора, но к тому времени, когда это берет, чтобы переместить данные в и из памяти. Один из самых важных методов для того, чтобы обходить это узкое место является кэш-памятью.

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

Одно из главных рабочих мест диспетчера тайника состоит в том, чтобы заботиться 'о последовательности тайника', что означает гарантировать, что любые изменения, написанные главной памяти, отражены в тайнике и наоборот. Есть несколько методов для того, чтобы достигнуть этого, самого очевидного существа для процессора, чтобы написать непосредственно и тайнику и главной памяти в то же самое время. Это известно, как “пишут - через” тайник, и самое безопасное решение, но также и самое медленное.

Главная альтернатива - "назад написанный" тайник, который позволяет процессору писать изменения только тайника а не главной памяти. Записи тайника, которые изменились, сигнализируются как 'грязные', говоря диспетчеру тайника написать их содержание в ответ главной памяти перед использованием пространства, чтобы припрятать новые данные про запас. Назад написанный тайник ускоряет написать процесс, но действительно требует более умного диспетчера тайника.

Большинство диспетчеров тайника перемещает 'линию' данных, а не только единственного пункта каждый раз, когда они должны передать данные между главной памятью и тайником. Это имеет тенденцию улучшать шанс хита тайника, поскольку большинство программ проводит свое время, ступая через инструкции, сохраненные последовательно в памяти, вместо того, чтобы суетиться от одной области до другого. Объем данных перешел, каждый раз известен как 'размер линии'.

Как Работает Дисковый Тайник

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

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