Kes Ingin tahu f; Mengapakah Ia Sentiasa Mencetak 1 dalam Output?
Menghadapi tingkah laku pelik di mana memanggil fungsi tanpa tanda kurungan (f;) dan mencetak hasilnya dengan std::cout secara konsisten menghasilkan nombor 1 boleh menimbulkan persoalan. Pada mulanya, seseorang mungkin menjangkakan kod akan mencetak penunjuk fungsi, tetapi pemerhatian menunjukkan sebaliknya.
Menyelidiki kod di bawah:
<code class="cpp">#include <iostream> using namespace std; void pr() { cout << "sth"; } int main() { pr; cout << pr; // output: 1 cout << *pr; // output: 1 cout << ≺ // output: 1 }
Kita dapat melihat bahawa pr; tidak secara teknikal memanggil fungsi pr(). Sebaliknya, penuding fungsi dihantar ke cout. Apabila penuding fungsi ditukar kepada bool semasa proses ini, ia berkelakuan serupa dengan ungkapan logik di mana nilai bukan sifar dinilai kepada benar. Ini diterjemahkan kepada 1 apabila dicetak.
Selain itu, dalam piawaian pra-C 11, tidak wujud lebihan beban yang membenarkan penstriman penunjuk fungsi. Ini menjadikan ia mencabar untuk memformat dan mencetak penunjuk fungsi secara langsung menggunakan std::cout. Walau bagaimanapun, dengan kemunculan C 11, seseorang boleh menentukan lebihan beban tersuai untuk mencapai ini:
<code class="cpp">template <class RType, class ... ArgTypes> std::ostream & operator<<(std::ostream & s, RType(*func)(ArgTypes...)) { return s << "(func_ptr=" << (void*)func << ")(num_args=" << sizeof...(ArgTypes) << ")"; }
Menggunakan lebihan beban ini, cout << pr kini akan mencetak:
<code class="text">(func_ptr=<address of pr>)(num_args=0)</code>
Beban tersuai ini menunjukkan penunjuk fungsi pencetakan yang berbeza-beza. Walaupun ia mengurangkan isu untuk penunjuk fungsi, ia tidak menyelesaikan sepenuhnya senario yang melibatkan fungsi terlampau beban atau templat fungsi yang menentukan lebihan beban yang diingini menjadi penting.
Atas ialah kandungan terperinci Mengapakah `std::cout. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!