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>
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>
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>
( 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>
Jika cukup besar, pecahkan blok. Pertama, kurangkan saiz blok semasa:
header->size = original_size - size - sizeof(header);
Kirakan penunjuk ke blok baru:
header *new_header = (header 1) header->size; // Corrected pointer calculation
Mulakan tajuk blok baru:
header_init(new_header, size, true);
Sambungkan blok baru ke senarai yang dipautkan:
header_plug(new_header, header, header->next);
Jika blok asal adalah blok terakhir, kemas kini penunjuk last
:
if (header == last) { last = new_header; }
Kembali ke blok baru:
return new_header; } else { return header; } }
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>
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











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.

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.

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.

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.

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.

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: 1. Okx, 2. Binance, 3. Coinbase, 4. Kraken, 5. Huobi, 6. Kucoin, 7.

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
