<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Cache-Algorithmus</id>
	<title>Cache-Algorithmus - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Cache-Algorithmus"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Cache-Algorithmus&amp;action=history"/>
	<updated>2026-05-18T23:58:57Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Cache-Algorithmus&amp;diff=271844&amp;oldid=prev</id>
		<title>imported&gt;Invisigoth67: typo</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Cache-Algorithmus&amp;diff=271844&amp;oldid=prev"/>
		<updated>2025-12-08T12:30:33Z</updated>

		<summary type="html">&lt;p&gt;typo&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{Belege fehlen}}&lt;br /&gt;
Ein &amp;#039;&amp;#039;&amp;#039;Cache-Algorithmus&amp;#039;&amp;#039;&amp;#039; ist ein [[Algorithmus]] zur Steuerung eines [[Cache]], mit dem Speicherzugriffe zwischen einer [[Hauptprozessor|CPU]] und dem [[Arbeitsspeicher]] optimiert und Inkonsistenzprobleme verhindert werden sollen. Caches im weiteren Sinne werden aber auch in [[Software]] verwendet, wo die Cache-Algorithmen entsprechend gelten.&lt;br /&gt;
&lt;br /&gt;
Es wird unterschieden zwischen {{lang|en|&amp;#039;&amp;#039;cache write policy&amp;#039;&amp;#039;}} (dt. Schreibregel) und {{lang|en|&amp;#039;&amp;#039;cache replacement policy&amp;#039;&amp;#039;}} (dt. Ersetzungsregel). Der Begriff Cache-Algorithmus wird im Englischen aber in der Regel nur auf {{lang|en|&amp;#039;&amp;#039;replacement policy&amp;#039;&amp;#039;}} bezogen.&lt;br /&gt;
&lt;br /&gt;
Bei der Betrachtung der Algorithmen unterscheidet man zudem zwischen {{lang|en|Cache Hit}} (angeforderte Daten liegen im Cache) und {{lang|en|Cache Miss}} (angeforderte Daten liegen nicht im Cache). Entsprechend heißen diese Situationen beim Lesen/Schreiben {{lang|en|Write Hit/Read Hit}} und {{lang|en|Write Miss/Read Miss}}.&lt;br /&gt;
&lt;br /&gt;
== Cache write policy ==&lt;br /&gt;
[[Datei:Cache Fill.svg|mini|hochkant=1.5|Verschiedene cache placement policies (hier nicht beschrieben)]]&lt;br /&gt;
&lt;br /&gt;
Die folgenden Methoden werden in der Regel in [[Rechnerarchitektur]]en mit einem Prozessor eingesetzt. Allerdings kann es hier zu Inkonsistenzen bei I/O-Operationen kommen. Der Cache-Block (auch Cacheline genannt) ist die kleinste Verwaltungseinheit innerhalb des Caches.&lt;br /&gt;
&lt;br /&gt;
=== Durchschreibetechnik ({{lang|en|write-through}}) ===&lt;br /&gt;
Bei {{lang|en|write-through}} ist normalerweise sichergestellt, dass die Daten im Cache und im dahinterliegenden Speicher (im Folgenden Hauptspeicher) gleich sind. Das wird dadurch erreicht, dass bei einem {{lang|en|Write Hit}} die Daten sowohl in den Cache als auch in den Hauptspeicher geladen werden. Bei einem Write Miss hängt es von der {{lang|en|&amp;#039;&amp;#039;Write-miss policy&amp;#039;&amp;#039;}} ab, ob die Daten neben dem Hauptspeicher auch in den Cache geladen werden.&lt;br /&gt;
&lt;br /&gt;
=== Rückschreibetechnik ({{lang|en|write-back}}) ===&lt;br /&gt;
Bei {{lang|en|write-back}} wird nicht direkt in den Hauptspeicher geschrieben, sondern dies geschieht erst, wenn der entsprechende Cache-Block ersetzt werden muss. Dies ist bei einem {{lang|en|Read Miss}} oder bei einem {{lang|en|Write Miss}} mit {{lang|en|write allocate}} (siehe {{lang|en|Write-miss policy}}) der Fall.&lt;br /&gt;
&lt;br /&gt;
Um zu erfassen, welche Daten mit dem Hauptspeicher übereinstimmen und welche nicht, wird das Dirty-Bit (= Daten im Hauptspeicher und Cache sind inkonsistent) gesetzt. Wenn das Dirty-Bit gesetzt ist, heißt das, dass die Daten noch nicht im Hauptspeicher stehen.&lt;br /&gt;
&lt;br /&gt;
Der Abgleich mit dem Hauptspeicher erfolgt, indem mit dem Dirty-Bit markierte Cachelines individuell in den Hauptspeicher geschrieben werden. Alternativ geschieht dies durch einen [[Cache#Cache Flush|FLUSH]], bei dem der gesamte Cache in den Hauptspeicher geschrieben wird.&lt;br /&gt;
&lt;br /&gt;
{{lang|en|Write-back}} ist zwar technisch anspruchsvoller, allerdings auch schneller als {{lang|en|&amp;#039;&amp;#039;write through&amp;#039;&amp;#039;}}.&lt;br /&gt;
&lt;br /&gt;
=== {{lang|en|Write-miss policy}} ===&lt;br /&gt;
Tritt ein {{lang|en|Write Miss}} auf, so kommt eine {{lang|en|&amp;#039;&amp;#039;Write-miss policy&amp;#039;&amp;#039;}} zum Einsatz.&lt;br /&gt;
&lt;br /&gt;
==== {{lang|en|Write allocate}} ====&lt;br /&gt;
Hier gelangen die zu schreibenden Daten direkt in den Cache. Sie werden aber auch in den Hauptspeicher geschrieben. Je nach Schreibtechnik ({{lang|en|write-through}}, {{lang|en|write-back}}) geschieht dies sofort oder bei Verdrängung der Cacheline.&lt;br /&gt;
&lt;br /&gt;
==== {{lang|en|No-write allocate}} ({{lang|en|write around}}) ====&lt;br /&gt;
Die Daten werden nur in den Hauptspeicher geschrieben, ohne eine Cacheline zu belegen.&lt;br /&gt;
&lt;br /&gt;
== {{lang|en|Cache replacement policy}} ==&lt;br /&gt;
Beim Lesen und beim Schreiben kommt es häufig vor, dass ein Cacheline ersetzt werden muss, weil der Cache voll ist. In diesem Fall muss die {{lang|en|&amp;#039;&amp;#039;Cache replacement policy&amp;#039;&amp;#039;}} – auch Cache-Algorithmus genannt – entscheiden, welche Cache-Blöcke verworfen werden und welche nicht.&lt;br /&gt;
&lt;br /&gt;
{{Siehe auch|Cache#Verdrängungsstrategien|titel1=Verdrängungsstrategien (Cache)}}&lt;br /&gt;
&lt;br /&gt;
== Multiprozessorsysteme ==&lt;br /&gt;
Bei [[Multiprozessorsystem]]en hat üblicherweise jeder Prozessor seinen eigenen Cache und greift darüber auf einen zentralen, gemeinsamen Speicher zu. Um Probleme durch Inkonsistenzen zwischen den Caches und dem Hauptspeicher zu verhindern, muss dann ein Cache-Algorithmus für [[Cache-Kohärenz]] sorgen.&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Algorithmus]]&lt;br /&gt;
[[Kategorie:Rechnerarchitektur]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Invisigoth67</name></author>
	</entry>
</feed>