Jadual Kandungan
Refactoring kod
Blok memori berpecah
Kemas kini Abmalloc ()
Nota mengenai segmentasi blok
Rumah pembangunan bahagian belakang C++ Melaksanakan malloc () dan percuma () - perpecahan besar

Melaksanakan malloc () dan percuma () - perpecahan besar

Apr 03, 2025 pm 10:57 PM
ai

Melaksanakan malloc () dan percuma () - perpecahan besar

Artikel sebelumnya meneroka kesan urutan penggunaan semula blok memori pada penggunaan memori dan fungsi yang dioptimumkan untuk mengurangkan sisa. Walau bagaimanapun, satu lagi masalah yang lebih serius berterusan: blok memori yang besar boleh menduduki pelbagai ruang kecil yang boleh dieksploitasi. Sebagai contoh, peruntukkan sebahagian besar memori, dan selepas pembebasan, peruntukkan dua ketulan yang lebih kecil:

 <code class="c">void *ptr1 = abmalloc(128); void *ptr2 = abmalloc(8); abfree(ptr1); void *ptr3 = abmalloc(8); void *ptr4 = abmalloc(8);</code>
Salin selepas log masuk

Pada masa ini, blok bebas 128-byte tidak dapat digunakan oleh permintaan 8-bait, mengakibatkan peruntukan blok 8-bait berikutnya yang memerlukan timbunan akan diperluaskan lagi, mengakibatkan penggunaan memori yang rendah.

Cara yang sangat cekap tetapi kompleks untuk menyelesaikan masalah ini ialah menggunakan "tong sampah": senarai ketulan yang dikelompokkan mengikut saiz. Satu lagi penyelesaian yang lebih mudah ialah memecah bahagian besar ke dalam ketulan yang lebih kecil. Artikel ini mengamalkan yang terakhir.

Refactoring kod

Pertama, refactor kod sedikit. Fungsi header_new() bertanggungjawab untuk memperuntukkan memori dan memulakan pengepala blok, yang tidak kondusif untuk pembacaan dan penyelenggaraan kod. Kami membahagikannya kepada dua fungsi:

  • header_plug() : Masukkan blok yang diasaskan antara blok sebelumnya dan seterusnya.
  • header_init() : Inisialisasi metadata (saiz dan ketersediaan) blok.

Mereka adalah seperti berikut:

 <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>
Salin selepas log masuk

Fungsi header_new() diubahsuai seperti berikut:

 <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>
Salin selepas log masuk

( last->previous->next = last; Dalam fungsi abmalloc() , baris ini boleh dipadam kerana header_plug() kini bertanggungjawab untuk mengendalikan logik ini.)

Blok memori berpecah

Seterusnya, laksanakan fungsi header_split() . Memandangkan tajuk blok dan saiz minimum yang diperlukan, jika blok asal cukup besar, memecahnya menjadi dua bahagian:

  • blok saiz yang diperlukan;
  • Baki dan blok baru;

Pertama, periksa sama ada blok itu cukup besar:

 <code class="c">header *header_split(header *header, size_t size) { size_t original_size = header->size; if (original_size >= size sizeof(header)) {</code>
Salin selepas log masuk

Jika cukup besar, pecahkan blok. Pertama, kurangkan saiz blok semasa:

 header->size = original_size - size - sizeof(header);
Salin selepas log masuk

Kirakan penunjuk ke blok baru:

 header *new_header = (header 1) header->size; // Corrected pointer calculation
Salin selepas log masuk

Mulakan tajuk blok baru:

 header_init(new_header, size, true);
Salin selepas log masuk

Sambungkan blok baru ke senarai yang dipautkan:

 header_plug(new_header, header, header->next);
Salin selepas log masuk

Jika blok asal adalah blok terakhir, kemas kini penunjuk last :

 if (header == last) { last = new_header; }
Salin selepas log masuk

Kembali ke blok baru:

 return new_header; } else { return header; } }
Salin selepas log masuk

Kemas kini Abmalloc ()

Akhirnya, ubah fungsi abmalloc() , dan selepas mencari blok yang ada, header_split() untuk cuba memecahnya:

 <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>
Salin selepas log masuk

Jika blok boleh dibahagikan, blok baru dikembalikan; Jika tidak, blok asal dikembalikan.

Nota mengenai segmentasi blok

Harus diingat bahawa blok baru dicipta pada akhir blok asal. Walaupun ia juga boleh dibuat pada mulanya, mewujudkan blok baru pada akhirnya boleh membawa blok percuma baru lebih dekat ke blok lama, meningkatkan kecekapan panggilan abmalloc() seterusnya.

Memisahkan potongan memori yang besar adalah satu langkah ke arah meningkatkan pengurusan ingatan, tetapi ia juga boleh menyebabkan ketulan kecil pemecahan ingatan, mengakibatkan permintaan yang lebih besar yang memerlukan pengembangan timbunan. Artikel seterusnya akan meneroka cara menyelesaikan masalah ini.

Atas ialah kandungan terperinci Melaksanakan malloc () dan percuma () - perpecahan besar. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1659
14
Tutorial PHP
1258
29
Tutorial C#
1232
24
Berapa bernilai bitcoin Berapa bernilai bitcoin Apr 28, 2025 pm 07:42 PM

Harga Bitcoin berkisar antara $ 20,000 hingga $ 30,000. 1. Harga Bitcoin telah berubah secara dramatik sejak tahun 2009, mencapai hampir $ 20,000 pada tahun 2017 dan hampir $ 60,000 pada tahun 2021. Harga dipengaruhi oleh faktor -faktor seperti permintaan pasaran, bekalan, dan persekitaran makroekonomi. 3. Dapatkan harga masa nyata melalui pertukaran, aplikasi mudah alih dan laman web. 4. Harga Bitcoin sangat tidak menentu, didorong oleh sentimen pasaran dan faktor luaran. 5. Ia mempunyai hubungan tertentu dengan pasaran kewangan tradisional dan dipengaruhi oleh pasaran saham global, kekuatan dolar AS, dan sebagainya. 6. Trend jangka panjang adalah yakin, tetapi risiko perlu dinilai dengan berhati-hati.

Platform perdagangan mata wang teratas yang manakah di dunia adalah antara sepuluh platform perdagangan mata wang teratas pada tahun 2025 Platform perdagangan mata wang teratas yang manakah di dunia adalah antara sepuluh platform perdagangan mata wang teratas pada tahun 2025 Apr 28, 2025 pm 08:12 PM

Sepuluh pertukaran cryptocurrency teratas di dunia pada tahun 2025 termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi, Bitfinex, Kucoin, Bittrex dan Poloniex, yang semuanya dikenali dengan jumlah dan keselamatan perdagangan mereka yang tinggi.

Platform perdagangan mata wang teratas yang manakah di dunia adalah versi terbaru dari Platform Perdagangan Top Top Top Platform perdagangan mata wang teratas yang manakah di dunia adalah versi terbaru dari Platform Perdagangan Top Top Top Apr 28, 2025 pm 08:09 PM

Sepuluh platform perdagangan cryptocurrency teratas di dunia termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi Global, Bitfinex, Bittrex, Kucoin dan Poloniex, yang semuanya menyediakan pelbagai kaedah perdagangan dan langkah -langkah keselamatan yang kuat.

Decryption Gate.IO Strategy Upgrade: Bagaimana untuk mentakrifkan semula Pengurusan Aset Crypto di Memebox 2.0? Decryption Gate.IO Strategy Upgrade: Bagaimana untuk mentakrifkan semula Pengurusan Aset Crypto di Memebox 2.0? Apr 28, 2025 pm 03:33 PM

Memebox 2.0 mentakrifkan semula pengurusan aset crypto melalui seni bina yang inovatif dan kejayaan prestasi. 1) Ia menyelesaikan tiga titik kesakitan utama: silo aset, kerosakan pendapatan dan paradoks keselamatan dan kemudahan. 2) Melalui hab aset pintar, pengurusan risiko dinamik dan enjin peningkatan pulangan, kelajuan pemindahan rantaian, kadar hasil purata dan kelajuan tindak balas insiden keselamatan diperbaiki. 3) Menyediakan pengguna dengan visualisasi aset, automasi dasar dan integrasi tadbir urus, merealisasikan pembinaan semula nilai pengguna. 4) Melalui kerjasama ekologi dan inovasi pematuhan, keberkesanan keseluruhan platform telah dipertingkatkan. 5) Pada masa akan datang, kolam insurans kontrak pintar, ramalan integrasi pasaran dan peruntukan aset yang didorong AI akan dilancarkan untuk terus memimpin pembangunan industri.

Apakah sepuluh aplikasi perdagangan mata wang maya teratas? Kedudukan pertukaran mata wang digital terkini Apakah sepuluh aplikasi perdagangan mata wang maya teratas? Kedudukan pertukaran mata wang digital terkini Apr 28, 2025 pm 08:03 PM

Sepuluh pertukaran mata wang digital teratas seperti Binance, OKX, Gate.io telah meningkatkan sistem mereka, urus niaga yang pelbagai dan langkah -langkah keselamatan yang ketat.

Apakah platform perdagangan mata wang teratas? 10 pertukaran mata wang maya terkini Apakah platform perdagangan mata wang teratas? 10 pertukaran mata wang maya terkini Apr 28, 2025 pm 08:06 PM

Saat ini disenaraikan di antara sepuluh mata wang mata wang maya yang teratas: 1. Binance, 2 Okx, 3. Gate.io, 4. Perpustakaan duit syiling, 5. Siren, 6. Huobi Global Station, 7. Bybit, 8. Kucoin, 9.

Platform perdagangan mata wang digital yang boleh dipercayai. 10 mata wang mata wang digital teratas di dunia. 2025 Platform perdagangan mata wang digital yang boleh dipercayai. 10 mata wang mata wang digital teratas di dunia. 2025 Apr 28, 2025 pm 04:30 PM

Platform perdagangan mata wang digital yang boleh dipercayai: 1. Okx, 2. Binance, 3. Coinbase, 4. Kraken, 5. Huobi, 6. Kucoin, 7.

Bagaimana cara menggunakan Perpustakaan Chrono di C? Bagaimana cara menggunakan Perpustakaan Chrono di C? Apr 28, 2025 pm 10:18 PM

Menggunakan perpustakaan Chrono di C membolehkan anda mengawal selang masa dan masa dengan lebih tepat. Mari kita meneroka pesona perpustakaan ini. Perpustakaan Chrono C adalah sebahagian daripada Perpustakaan Standard, yang menyediakan cara moden untuk menangani selang waktu dan masa. Bagi pengaturcara yang telah menderita dari masa. H dan CTime, Chrono tidak diragukan lagi. Ia bukan sahaja meningkatkan kebolehbacaan dan mengekalkan kod, tetapi juga memberikan ketepatan dan fleksibiliti yang lebih tinggi. Mari kita mulakan dengan asas -asas. Perpustakaan Chrono terutamanya termasuk komponen utama berikut: STD :: Chrono :: System_Clock: Mewakili jam sistem, yang digunakan untuk mendapatkan masa semasa. Std :: Chron

See all articles