cari
Rumahpembangunan bahagian belakangC++Melaksanakan malloc () dan percuma () - perpecahan besar

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="language-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="language-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="language-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="language-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="language-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!

Kenyataan
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
Rangka Kerja C XML: Memilih yang sesuai untuk andaRangka Kerja C XML: Memilih yang sesuai untuk andaApr 30, 2025 am 12:01 AM

Pilihan kerangka C XML harus berdasarkan keperluan projek. 1) TinyXML sesuai untuk persekitaran yang terkawal sumber, 2) PugixML sesuai untuk keperluan berprestasi tinggi, 3) Xerces-C menyokong pengesahan XMLSchema kompleks, dan prestasi, kemudahan penggunaan dan lesen mesti dipertimbangkan ketika memilih.

C# vs C: Memilih bahasa yang sesuai untuk projek andaC# vs C: Memilih bahasa yang sesuai untuk projek andaApr 29, 2025 am 12:51 AM

C# sesuai untuk projek yang memerlukan kecekapan pembangunan dan keselamatan jenis, manakala C sesuai untuk projek yang memerlukan prestasi tinggi dan kawalan perkakasan. 1) C# menyediakan koleksi sampah dan LINQ, sesuai untuk aplikasi perusahaan dan pembangunan Windows. 2) C dikenali dengan prestasi tinggi dan kawalan asasnya, dan digunakan secara meluas dalam pengaturcaraan permainan dan sistem.

Cara Mengoptimumkan KodCara Mengoptimumkan KodApr 28, 2025 pm 10:27 PM

Pengoptimuman kod C boleh dicapai melalui strategi berikut: 1. Menguruskan memori secara manual untuk penggunaan pengoptimuman; 2. Tulis kod yang mematuhi peraturan pengoptimuman pengkompil; 3. Pilih algoritma dan struktur data yang sesuai; 4. Gunakan fungsi inline untuk mengurangkan overhead panggilan; 5. Memohon template metaprogramming untuk mengoptimumkan pada masa penyusunan; 6. Elakkan penyalinan yang tidak perlu, gunakan semantik bergerak dan parameter rujukan; 7. Gunakan Const dengan betul untuk membantu pengoptimuman pengkompil; 8. Pilih struktur data yang sesuai, seperti STD :: vektor.

Bagaimana untuk memahami kata kunci yang tidak menentu di C?Bagaimana untuk memahami kata kunci yang tidak menentu di C?Apr 28, 2025 pm 10:24 PM

Kata kunci yang tidak menentu dalam C digunakan untuk memaklumkan pengkompil bahawa nilai pembolehubah boleh diubah di luar kawalan kod dan oleh itu tidak dapat dioptimumkan. 1) Ia sering digunakan untuk membaca pembolehubah yang boleh diubahsuai oleh perkakasan atau program perkhidmatan mengganggu, seperti keadaan sensor. 2) Tidak menentu tidak dapat menjamin keselamatan multi-thread, dan harus menggunakan kunci mutex atau operasi atom. 3) Menggunakan tidak menentu boleh menyebabkan prestasi sedikit berkurangan, tetapi memastikan ketepatan program.

Bagaimana untuk mengukur prestasi benang di C?Bagaimana untuk mengukur prestasi benang di C?Apr 28, 2025 pm 10:21 PM

Mengukur prestasi thread di C boleh menggunakan alat masa, alat analisis prestasi, dan pemasa tersuai di perpustakaan standard. 1. Gunakan perpustakaan untuk mengukur masa pelaksanaan. 2. Gunakan GPROF untuk analisis prestasi. Langkah -langkah termasuk menambah pilihan -pg semasa penyusunan, menjalankan program untuk menghasilkan fail gmon.out, dan menghasilkan laporan prestasi. 3. Gunakan modul Callgrind Valgrind untuk melakukan analisis yang lebih terperinci. Langkah -langkah termasuk menjalankan program untuk menghasilkan fail callgrind.out dan melihat hasil menggunakan kcachegrind. 4. Pemasa tersuai secara fleksibel dapat mengukur masa pelaksanaan segmen kod tertentu. Kaedah ini membantu memahami sepenuhnya prestasi benang dan mengoptimumkan kod.

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

Apakah pengaturcaraan sistem operasi masa nyata di C?Apakah pengaturcaraan sistem operasi masa nyata di C?Apr 28, 2025 pm 10:15 PM

C berfungsi dengan baik dalam pengaturcaraan sistem operasi masa nyata (RTOS), menyediakan kecekapan pelaksanaan yang cekap dan pengurusan masa yang tepat. 1) C memenuhi keperluan RTO melalui operasi langsung sumber perkakasan dan pengurusan memori yang cekap. 2) Menggunakan ciri berorientasikan objek, C boleh merancang sistem penjadualan tugas yang fleksibel. 3) C menyokong pemprosesan gangguan yang cekap, tetapi peruntukan memori dinamik dan pemprosesan pengecualian mesti dielakkan untuk memastikan masa nyata. 4) Pemrograman templat dan fungsi sebaris membantu dalam pengoptimuman prestasi. 5) Dalam aplikasi praktikal, C boleh digunakan untuk melaksanakan sistem pembalakan yang cekap.

Bagaimana untuk memahami keserasian ABI dalam C?Bagaimana untuk memahami keserasian ABI dalam C?Apr 28, 2025 pm 10:12 PM

Keserasian ABI dalam C merujuk kepada sama ada kod binari yang dihasilkan oleh penyusun atau versi yang berbeza boleh serasi tanpa rekompilasi. 1. Konvensyen Calling Function, 2. Pengubahsuaian Nama, 3. Susun atur Jadual Fungsi Maya, 4. Struktur dan susun atur kelas adalah aspek utama yang terlibat.

See all articles

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

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna