Mengapa Memanggil std::string.c_str() pada Fungsi Mengembalikan Rentetan Gagal
Pertimbangkan kod berikut:
<code class="cpp">std::string getString() { std::string str("hello"); return str; } int main() { const char* cStr = getString().c_str(); std::cout << cStr << std::endl; // Outputs garbage }</code>
Secara intuitif, seseorang menjangkakan rentetan sementara yang dikembalikan daripada getString() kekal sah dalam skop main(). Walau bagaimanapun, ini tidak betul.
Isunya terletak pada jangka hayat objek sementara dalam C . Objek sementara dimusnahkan pada penghujung ungkapan yang ia dicipta, melainkan ia terikat pada rujukan atau digunakan untuk memulakan objek bernama. Dalam kes ini, getString() mengembalikan rentetan sementara, yang dimusnahkan pada penghujung ungkapan dalam main().
Oleh itu, cStr memegang penunjuk berjuntai dan menggunakannya boleh membawa kepada tingkah laku yang tidak ditentukan. Untuk mengelakkan masalah ini, seseorang boleh menggunakan pembolehubah bernama atau rujukan untuk memastikan kesahihan rentetan yang dikembalikan. Contohnya:
<code class="cpp">std::string returnedString = getString(); const char* cStr = returnedString.c_str(); std::cout << cStr << std::endl; // Safe</code>
Sebagai alternatif, rentetan sementara boleh digunakan secara langsung tanpa memperuntukkannya kepada pembolehubah:
<code class="cpp">std::cout << getString().c_str() << std::endl; // Also safe</code>
Atas ialah kandungan terperinci Berikut ialah beberapa pilihan tajuk yang sesuai dengan format soalan-jawapan dan menerangkan kandungan artikel dengan tepat: **Pilihan 1 (Pendek & Langsung):** * **Mengapa Memanggil `std::string.c_str()` pada Re. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!