Helo, Mentes Tech!
Adakah anda tahu apakah pengiraan rujukan dan penjejakan rujukan dalam konteks penyerahan peruntukan memori?
Perbezaan antara penjejakan rujukan (atau menjejak kutipan sampah) dan pengiraan rujukan (pengiraan rujukan) terletak pada pendekatan yang digunakan setiap teknik untuk mengenal pasti dan membebaskan memori objek yang tiada lebih lama digunakan.
Saya akan menerangkan setiap satu dan kemudian menyerlahkan perbezaan utama.
Pengiraan Rujukan (Pengiraan Rujukan)
Cara ia berfungsi: Setiap objek dalam ingatan mempunyai pembilang yang menjejaki bilangan rujukan (atau penunjuk) yang menunjuk kepadanya. Apabila rujukan baharu kepada objek dibuat, pembilang akan dinaikkan. Apabila rujukan dialih keluar, kaunter dikurangkan. Jika pembilang mencapai sifar, ini bermakna objek tidak lagi boleh diakses dan boleh dibebaskan (ingatannya boleh diingat semula).
-
Kelebihan:
- Mudah untuk difahami dan dilaksanakan.
- Mengumpul ingatan serta-merta apabila pembilang mencapai sifar, yang boleh mengurangkan jumlah memori yang digunakan.
-
Kelemahan:
-
Kitaran Rujukan: Jika dua atau lebih objek merujuk antara satu sama lain dalam kitaran, kiraan rujukannya tidak pernah mencapai sifar, menyebabkan kebocoran memori.
- Mungkin kurang cekap kerana setiap penciptaan atau pengalihan keluar rujukan memerlukan kemas kini balas, yang mungkin mempunyai kesan prestasi.
Penjejakan Rujukan (Menjejak Pengumpulan Sampah)
Cara ia berfungsi: Pendekatan ini melibatkan dua fasa utama: penandaan dan pengimbasan. Pertama, pengumpul sampah bermula dari akar (seperti pembolehubah global, pembolehubah tempatan dan daftar) dan menjejaki semua rujukan kepada objek dalam ingatan, menandakan rujukan yang boleh diakses. Ia kemudian mengimbas memori untuk mengumpul objek (percuma) yang belum ditanda, kerana ini tidak lagi boleh diakses.
-
Kelebihan:
- Tidak mengalami masalah kitaran rujukan, kerana pemungut sampah dapat mengenal pasti objek yang tidak lagi boleh diakses, tanpa mengira kitaran.
- Mungkin lebih cekap dari segi masa jalan untuk jenis aplikasi tertentu, terutamanya dalam bahasa dengan pengurusan memori yang kompleks.
-
Kelemahan:
- Ia boleh memperkenalkan jeda dalam pelaksanaan program, walaupun pengumpul sampah moden, seperti Go, direka untuk meminimumkan jeda ini.
- Secara amnya, proses penjejakan boleh menjadi lebih kompleks dan intensif sumber berbanding pengiraan rujukan, bergantung pada cara pemungut sampah dilaksanakan.
Perbezaan Utama
-
Pengurusan Kitaran:
- Pengiraan Rujukan: Masalah dengan kitaran rujukan, di mana dua atau lebih objek merujuk antara satu sama lain, mengakibatkan kebocoran memori.
- Penjejakan: Tiada masalah dengan kitaran, kerana pengumpul menjejak dan menanda semua objek yang boleh diakses.
-
Kerumitan dan Prestasi:
- Kiraan Rujukan: Mudah, tetapi setiap operasi kenaikan dan pengurangan boleh memberi kesan kepada prestasi, terutamanya dalam program yang melakukan banyak operasi dengan penunjuk.
- Pengesanan: Lebih kompleks dan boleh menyebabkan jeda dalam pelaksanaan program, tetapi secara amnya lebih cekap dalam menangani corak penggunaan memori yang berbeza.
-
Masa Pengumpulan:
- Kiraan Rujukan: Mengumpul ingatan serta-merta apabila kiraan mencecah sifar.
- Penjejakan: Mengumpul ingatan secara berkala, apabila pemungut sampah menjalankan kitarannya.
-
Pelaksanaan:
- Kiraan Rujukan: Lebih mudah untuk dilaksanakan, tetapi kurang mantap dalam aplikasi yang kompleks.
- Penjejakan: Lebih mantap, tetapi melaksanakan pemungut sampah boleh menjadi agak rumit.
Ringkasnya, pengiraan rujukan adalah lebih mudah dan lebih segera, tetapi mungkin gagal dalam senario tertentu (seperti kitaran rujukan), manakala penjejakan lebih teguh dan fleksibel, tetapi mungkin mempunyai kesan yang lebih besar terhadap prestasi disebabkan kerumitan pelaksanaan.
Atas ialah kandungan terperinci Pengiraan Rujukan vs Mengesan Kutipan Sampah. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!