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!

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# 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.

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.

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.

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.

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

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.

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.


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

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna
