Mezera mezery - Gap buffer - Wikipedia
tento článek potřebuje další citace pro ověření.Duben 2012) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) ( |
A vyrovnávací paměť mezery v počítačová věda je dynamické pole který umožňuje efektivní operace vkládání a mazání seskupené poblíž stejného místa. Mezery mezipaměti jsou obzvláště běžné v textové editory, kde většina změn textu nastává na aktuálním místě nebo v jeho blízkosti kurzor. Text je uložen ve velké vyrovnávací paměti ve dvou sousedících segmentech, přičemž mezi nimi je mezera pro vložení nového textu. Pohyb kurzoru zahrnuje kopírování textu z jedné strany mezery na druhou (někdy se kopírování zpozdí až do další operace, která změní text). Vložení přidá nový text na konec prvního segmentu; vymazání to smaže.
Text ve vyrovnávací paměti mezery je reprezentován jako dva struny, které zabírají jen velmi málo místa navíc a které lze ve srovnání s propracovanějšími vyhledávat a zobrazovat velmi rychle datové struktury jako propojené seznamy. Operace na různých místech v textu a na těch, které vyplňují mezeru (vyžadující vytvoření nové mezery), však mohou vyžadovat kopírování většiny textu, což je zvláště neúčinné pro velké soubory. Použití mezerových vyrovnávacích pamětí je založeno na předpokladu, že k takovému překódování dochází zřídka natolik, že jeho náklady mohou být amortizovaný přes běžnější levné operace. Díky tomu je vyrovnávací paměť mezery jednodušší alternativou k lano pro použití v textových editorech[1] jako Emacs.[2]
Příklad
Níže uvádíme několik příkladů operací s mezerami ve vyrovnávací paměti. Mezeru představuje prázdné místo mezi hranatými závorkami. Tato reprezentace je trochu zavádějící: v typické implementaci jsou sledovány koncové body mezery pomocí ukazatele nebo maticové indexy a obsah mezery je ignorován; to umožňuje například odstranění, které lze provést úpravou ukazatele beze změny textu ve vyrovnávací paměti. Běžnou programovací praxí je použití polootevřeného intervalu pro ukazatele mezery, tj. Začátek mezery ukazuje na neplatný znak následující za posledním znakem v první vyrovnávací paměti a konec mezery ukazuje na první mezeru platný znak ve druhé vyrovnávací paměti (nebo ekvivalentně jsou ukazatele považovány za body „mezi“ znaky).
Počáteční stav:
Toto je cesta [] ven.
Uživatel vloží nový text:
Takto začal svět [].
Uživatel pohybuje kurzorem před „spuštěním“; systém přesune "spuštěno" z prvního bufferu do druhého bufferu.
Takto začal svět [].
Uživatel přidá text vyplňující mezeru; systém vytváří novou mezeru:
Takhle začal svět, jak ho známe [].
Viz také
- Dynamické pole, speciální případ vyrovnávací paměti mezery, kde je mezera vždy na konci
- Zip (datová struktura), koncepčně zevšeobecnění vyrovnávací paměti mezery.
- Spojový seznam
- Kruhový nárazník
- Lano (informatika)
- Kusový stůl - datová struktura používaná programy Bravo a Microsoft Word
Reference
- ^ Mark C. Chu-Carroll. "Gap Buffers, or, Don’t Get Tied Up With Ropes? " ScienceBlogy, 18. 02. 2009. Zpřístupněno 30. 1. 2013.
- ^ emacs mezipaměť informace Zpřístupněno 30. 1. 2013.
externí odkazy
- Přehled a implementace v .NET / C #
- Stručný přehled a ukázkový kód C ++
- Implementace cyklické tříděné vyrovnávací paměti mezery v .NET / C #
- Využití vyrovnávací paměti mezery v časném editoru. (Poprvé napsáno někde v letech 1969 až 1971)
- emacs mezipaměť informace (Reference vyrovnávací paměti Emacs)
- Úpravy textu