Inhaltsverzeichnis
Code Refactoring
Speicherblöcke geteilt
ABMALLOC () aktualisieren
Hinweise zur Blocksegmentierung
Heim Backend-Entwicklung C++ Malloc () und Free () implementieren - teilen große Stücke auf

Malloc () und Free () implementieren - teilen große Stücke auf

Apr 03, 2025 pm 10:57 PM
ai

Malloc () und Free () implementieren - teilen große Stücke auf

Der vorherige Artikel untersuchte die Auswirkungen der Wiederverwendung der Speicherblock -Wiederverwendung auf den Speicherverbrauch und optimierte Funktionen zur Reduzierung von Abfällen. Ein weiteres ernsthafteres Problem bleibt jedoch bestehen: Ein riesiger Speicherblock kann mehrere kleine Raumblöcke einnehmen, die ausgenutzt werden können. Weisen Sie beispielsweise einen großen Teil des Gedächtnisses aus und geben Sie nach der Veröffentlichung zwei kleinere Stücke aus:

 <code class="c">void *ptr1 = abmalloc(128); void *ptr2 = abmalloc(8); abfree(ptr1); void *ptr3 = abmalloc(8); void *ptr4 = abmalloc(8);</code>
Nach dem Login kopieren

Zu diesem Zeitpunkt kann der 128-Byte-freie Block nicht von der 8-Byte-Anforderung verwendet werden, was zu der nachfolgenden 8-Byte-Blockzuweisung führt, bei der der Haufen erneut erweitert werden muss, was zu einer geringen Speicherauslastung führt.

Eine hocheffiziente, aber komplexe Möglichkeit, dieses Problem zu lösen, besteht darin, "Mülleimer" zu verwenden: eine Liste von Stücken, die nach Größe gruppiert sind. Eine weitere einfachere Lösung besteht darin, die großen Stücke in kleinere Stücke zu teilen. Dieser Artikel übernimmt letztere.

Code Refactoring

Um den Code geringfügig zu refaktor. header_new() ist verantwortlich für die Zuordnung von Speicher und die Initialisierung von Blockheadern, was der Lesbarkeit und Wartung des Codes nicht förderlich ist. Wir teilen es in zwei Funktionen auf:

  • header_plug() : Fügen Sie den initialisierten Block zwischen den vorherigen und nächsten Blöcken ein.
  • header_init() : Initialisieren Sie die Metadaten (Größe und Verfügbarkeit) des Blocks.

Sie sind wie folgt:

 <code class="c">void header_init(header *header, size_t size, bool available) { header->size = size; header->available = available; } void header_plug(header *header, header *previous, header *next) { header->previous = previous; if (previous != NULL) { previous->next = header; } header->next = next; if (next != NULL) { next->previous = header; } }</code>
Nach dem Login kopieren

header_new() wird wie folgt geändert:

 <code class="c">header *header_new(header *previous, size_t size, bool available) { header *header = sbrk(sizeof(header) size); header_init(header, size, available); header_plug(header, previous, NULL); return header; }</code>
Nach dem Login kopieren

( last->previous->next = last; In abmalloc() kann diese Zeile gelöscht werden, da header_plug() jetzt für die Behandlung dieser Logik verantwortlich ist.)

Speicherblöcke geteilt

Implementieren Sie als nächstes header_split() . Wenn der ursprüngliche Block groß genug ist, teilen Sie ihn in zwei Teile auf:

  • Blöcke der erforderlichen Größe;
  • Der Rest und seine neuen Blöcke;

Überprüfen Sie zunächst, ob der Block groß genug ist:

 <code class="c">header *header_split(header *header, size_t size) { size_t original_size = header->size; if (original_size >= size sizeof(header)) {</code>
Nach dem Login kopieren

Wenn groß genug, teilen Sie den Block auf. Reduzieren Sie zunächst die Größe des aktuellen Blocks:

 header->size = original_size - size - sizeof(header);
Nach dem Login kopieren

Berechnen Sie den Zeiger auf den neuen Block:

 header *new_header = (header 1) header->size; // Corrected pointer calculation
Nach dem Login kopieren

Initialisieren Sie den Header eines neuen Blocks:

 header_init(new_header, size, true);
Nach dem Login kopieren

Schließen Sie den neuen Block mit der verknüpften Liste an:

 header_plug(new_header, header, header->next);
Nach dem Login kopieren

Wenn der ursprüngliche Block der letzte Block ist, aktualisieren Sie last Zeiger:

 if (header == last) { last = new_header; }
Nach dem Login kopieren

Kehren Sie zum neuen Block zurück:

 return new_header; } else { return header; } }
Nach dem Login kopieren

ABMALLOC () aktualisieren

Ändern Sie schließlich die Funktion abmalloc() und aufrufen, um den verfügbaren Block zu finden, rufen Sie header_split() auf, um zu versuchen, ihn zu teilen:

 <code class="c">if (header->available && (header->size >= size)) { header = header_split(header, size); header->available = false; return (void*)(header 1); // Cast to void* for correct return type }</code>
Nach dem Login kopieren

Wenn der Block geteilt werden kann, wird der neue Block zurückgegeben. Andernfalls wird der ursprüngliche Block zurückgegeben.

Hinweise zur Blocksegmentierung

Es ist zu beachten, dass der neue Block am Ende des ursprünglichen Blocks erstellt wird. Obwohl es am Anfang auch erstellt werden kann, kann das Erstellen eines neuen Blocks am Ende den neuen freien Block näher an den alten Block bringen, wodurch die Effizienz des nächsten abmalloc() -Anrufs verbessert wird.

Die Aufteilung großer Speicherbrocken ist ein Schritt zur Verbesserung der Speicherverwaltung, kann jedoch auch zu kleinen Stücken der Speicherfragmentierung führen, was zu größeren Anforderungen führt, die eine Ausdehnung des Haufens erfordern. Im nächsten Artikel wird untersucht, wie dieses Problem gelöst werden kann.

Das obige ist der detaillierte Inhalt vonMalloc () und Free () implementieren - teilen große Stücke auf. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1673
14
PHP-Tutorial
1277
29
C#-Tutorial
1257
24
Top 10 Handelsplattformen für digitale Währung: Top 10 sichere und zuverlässige Digitalwährungsbörsen Top 10 Handelsplattformen für digitale Währung: Top 10 sichere und zuverlässige Digitalwährungsbörsen Apr 30, 2025 pm 04:30 PM

Die Top 10 Top -Plattformen für virtuelle Währung sind: 1. Binance, 2. OKX, 3. Coinbase, 4. Kraken, 5. Huobi Global, 6. Bitfinex, 7. Kucoin, 8. Gemini, 9. Bitstamp, 10. Bittrex. Diese Plattformen bieten alle hohe Sicherheit und eine Vielzahl von Handelsoptionen, die für unterschiedliche Benutzeranforderungen geeignet sind.

Quantitative Exchange -Ranking 2025 Top 10 Empfehlungen für digitale Währung Quantitative Handels -Apps Quantitative Exchange -Ranking 2025 Top 10 Empfehlungen für digitale Währung Quantitative Handels -Apps Apr 30, 2025 pm 07:24 PM

Zu den integrierten Quantisierungstools am Austausch gehören: 1. Binance: Binance Futures Quantitatives Modul, niedrige Handhabungsgebühren und unterstützt AI-unterstützte Transaktionen. 2. OKX (OUYI): Unterstützt Multi-Account-Management und intelligentes Auftragsrouting und bietet Risikokontrolle auf institutioneller Ebene. Zu den unabhängigen quantitativen Strategieplattformen gehören: 3. 3Commas: Drag & drop-Strategiegenerator, geeignet für Multi-Plattform-Absicherungs-Arbitrage. 4. Viercy: Algorithmus-Strategie-Bibliothek auf professioneller Ebene, unterstützt maßgeschneiderte Risikoschwellen. 5. Pionex: Integrierte 16 voreingestellte Strategie, niedrige Transaktionsgebühr. Zu den vertikalen Domänen-Tools gehören: 6. CryptoHopper: Cloud-basierte quantitative Plattform, die 150 technische Indikatoren unterstützen. 7. Bitsgap:

EasProtocol.com implementiert den ISO 20022 -Nachrichtenstandard direkt als Blockchain -Smart -Vertrag EasProtocol.com implementiert den ISO 20022 -Nachrichtenstandard direkt als Blockchain -Smart -Vertrag Apr 30, 2025 pm 05:06 PM

Diese bahnbrechende Entwicklung wird es Finanzinstituten ermöglichen, den global anerkannten ISO20022 -Standard zu nutzen, um Bankverfahren über verschiedene Blockchain -Ökosysteme hinweg zu automatisieren. Das Easy Protocol ist eine Blockchain-Plattform auf Unternehmensebene, die die weit verbreitete Akzeptanz durch einfach zu verwendende Methoden fördert. Es gab heute bekannt, dass es den ISO20022 -Messaging -Standard erfolgreich integriert und direkt in Blockchain -Smart Contracts integriert hat. Diese Entwicklung wird es Finanzinstituten ermöglichen, Bankenprozesse in verschiedenen Blockchain -Ökosystemen mit dem global anerkannten ISO20022 -Standard zu automatisieren, der das Swift Messaging -System ersetzt. Diese Funktionen werden in Kürze auf "DEALETESTNET" ausprobiert. EasProtokolarchitektdou

Gibt es eine Zukunft für Apps für digitale Währung? Apple Mobile Digital Currency Trading Platform App Download Top10 Gibt es eine Zukunft für Apps für digitale Währung? Apple Mobile Digital Currency Trading Platform App Download Top10 Apr 30, 2025 pm 07:00 PM

Die Aussichten von Apps für digitale Währung sind breit, was sich speziell in: 1. technologische Upgrades für innovationsgetriebene Funktionen widerspiegelt und die Benutzererfahrung durch die Integration von Defi- und NFT- und KI- und Big-Data-Anwendungen verbessert. 2. Trends der Vorschriften, globale Rahmenverbesserungen und strengere Anforderungen für AML und KYC; 3.. Funktionsdiversifizierung und Serviceerweiterung, Integration von Krediten, Finanzmanagement und anderen Diensten und Optimierung der Benutzererfahrung; 4. Die Benutzerbasis und die globale Erweiterung und die Benutzerskala wird voraussichtlich im Jahr 2025 1 Milliarde überschreiten.

Fehlgeschlagene Crypto Exchange FTX ergriffen rechtliche Schritte gegen bestimmte Emittenten in den letzten Versuch Fehlgeschlagene Crypto Exchange FTX ergriffen rechtliche Schritte gegen bestimmte Emittenten in den letzten Versuch Apr 30, 2025 pm 05:24 PM

In seinem jüngsten Versuch hat der entschlossene Crypto Exchange FTX rechtliche Schritte eingeleitet, um Schulden zurückzufordern und Kunden zurückzuzahlen. Bei den jüngsten Bemühungen, Schulden zurückzuerobern und Kunden zurückzuzahlen, hat der gelöste Crypto Exchange FTX rechtliche Schritte gegen bestimmte Emittenten eingereicht. FTX Trading und FTX Recovery Trust haben Klagen gegen bestimmte Token -Emittenten eingereicht, die ihre Vereinbarung über die Überweisung vereinbarter Münzen an die Börse nicht erfüllt haben. Insbesondere verklagte das Umstrukturierungsteam am Montag NFTStars Limited und Orosemi Inc. wegen Compliance -Problemen. FTX verklagt den Token -Emittenten, um die abgelaufenen Münzen zurückzufordern. FTX war einst eine der herausragendsten Kryptowährungs -Handelsplattformen in den USA. Die Bank berichtete im November 2022, dass ihr Gründer Sam

Was sind die drei Riesen im Währungskreis? Top 10 empfohlene Virtual Currency Main Exchange Apps Was sind die drei Riesen im Währungskreis? Top 10 empfohlene Virtual Currency Main Exchange Apps Apr 30, 2025 pm 06:27 PM

Im Währungskreis bezieht sich die sogenannten Big Three normalerweise auf die drei einflussreichsten und weit verbreiteten Kryptowährungen. Diese Kryptowährungen spielen eine bedeutende Rolle auf dem Markt und haben sich in Bezug auf das Transaktionsvolumen und die Marktkapitalisierung gut entwickelt. Gleichzeitig ist die App Virtual Currency Exchange -App der Mainstream auch ein wichtiges Instrument für Anleger und Händler, um Kryptowährungshandel durchzuführen. In diesem Artikel werden die drei Riesen im Währungskreis und die zehn wichtigsten Virtual Currency Currency Exchange -Apps empfohlen.

Was sind die zuverlässigen Austauschplattformen? Die zehn besten Währungsbörsen digitaler Währung Was sind die zuverlässigen Austauschplattformen? Die zehn besten Währungsbörsen digitaler Währung Apr 30, 2025 pm 04:15 PM

Die zehn Top -Börsen für digitale Währungen sind: 1. Binance, 2. OKX, 3. Coinbase, 4. Kraken, 5. Huobi Global, 6. Bitfinex, 7. Kucoin, 8. Gemini, 9. Bitstamp, 10. Bittrex. Diese Plattformen bieten alle hohe Sicherheit und eine Vielzahl von Handelsoptionen, die für verschiedene Benutzeranforderungen geeignet sind.

Top 10 Kryptowährungsplattformen der Welt, die die Unterstützung von Multi-Chain-Transaktionen unterstützen, werden im Jahr 2025 maßgeblich veröffentlicht Top 10 Kryptowährungsplattformen der Welt, die die Unterstützung von Multi-Chain-Transaktionen unterstützen, werden im Jahr 2025 maßgeblich veröffentlicht May 08, 2025 pm 07:15 PM

Nach den neuesten Bewertungen und Branchentrends von maßgeblichen Institutionen im Jahr 2025 sind die folgenden Top-zehn Kryptowährungsplattformen der Welt, die Multi-Chain-Transaktionen unterstützen und Transaktionsvolumen, technologische Innovation, Compliance und umfassende Reputation umfassen: umfassende Analyse:

See all articles