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>
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>
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>
( 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>
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);
Berechnen Sie den Zeiger auf den neuen Block:
header *new_header = (header 1) header->size; // Corrected pointer calculation
Initialisieren Sie den Header eines neuen Blocks:
header_init(new_header, size, true);
Schließen Sie den neuen Block mit der verknüpften Liste an:
header_plug(new_header, header, header->next);
Wenn der ursprüngliche Block der letzte Block ist, aktualisieren Sie last
Zeiger:
if (header == last) { last = new_header; }
Kehren Sie zum neuen Block zurück:
return new_header; } else { return header; } }
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>
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!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











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.

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:

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

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.

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

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.

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.

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:
