Mengembalikan Tatasusunan Tempatan dalam C : Mengelakkan Kebocoran Memori
Dalam C , mengembalikan tatasusunan setempat boleh menyebabkan kebocoran memori. Pertimbangkan contoh berikut:
char *recvmsg() { char buffer[1024]; return buffer; } int main() { char *reply = recvmsg(); ... }
Di sini, fungsi recvmsg mengembalikan penuding kepada penimbal tatasusunan setempat. Walau bagaimanapun, tatasusunan ini dimusnahkan apabila fungsi itu kembali, meninggalkan penunjuk berjuntai. Mengakses penuding ini kemudian akan mengakibatkan tingkah laku yang tidak ditentukan, yang berpotensi membawa kepada kebocoran ingatan.
Mengembalikan std::vector
Untuk menyelesaikan isu ini, seseorang boleh mengembalikan std::vector
std::vector<char> recvmsg() { std::vector<char> buffer(1024); ... return buffer; } int main() { std::vector<char> reply = recvmsg(); }
Menggunakan char* dengan std::vector
Jika anda perlu menggunakan char* di tempat lain dalam kod, anda boleh menggunakan &reply[0] untuk mendapatkan penunjuk kepada elemen pertama std::vector. Contohnya:
void f(const char* data, size_t size) {} f(&reply[0], reply.size());
Elakkan Penggunaan yang baharu
Akhir sekali, adalah disyorkan untuk mengelak daripada menggunakan yang baharu sebanyak mungkin. Menguruskan memori secara manual dengan yang baharu boleh menyebabkan kebocoran memori jika memori yang diperuntukkan tidak diagihkan dengan betul. Sebaliknya, bergantung pada bekas seperti std::vector yang mengurus memori secara automatik.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengembalikan Tatasusunan dengan Selamat daripada Fungsi C dan Mengelakkan Kebocoran Memori?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!