Meniru Warisan Templat dengan Inferens Jenis Automatik
Keupayaan untuk menentukan hujah templat secara automatik menggunakan auto akan menyediakan jalan pintas yang mudah dalam situasi di mana menaip secara eksplisit keluar jenis penuh boleh membosankan atau kompleks. Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa pada masa ini C tidak menyokong emulasi langsung templat
Menggunakan Makro untuk Menghantar Argumen Mudah
Sebagai penyelesaian, makro boleh digunakan untuk mensimulasikan inferens jenis automatik. Pertimbangkan contoh berikut:
<code class="cpp">#define AUTO_ARG(x) decltype(x), x Foo f; f.bar<AUTO_ARG(5)>(); // Equivalent to f.bar<int, 5>() f.bar<AUTO_ARG(&Baz::bang)>(); // Equivalent to f.bar<decltype(&Baz::bang), &Baz::bang>()</code>
Walaupun pendekatan ini boleh memudahkan sintaks panggilan, pendekatan ini memperkenalkan kemungkinan perangkap dan memerlukan panggilan makro yang jelas.
Memanfaatkan Penjana Templat untuk Potongan Automatik
Penyelesaian alternatif melibatkan mencipta fungsi penjana templat:
<code class="cpp">template <typename T> struct foo { foo(const T&) {} // Perform specific actions }; template <typename T> foo<T> make_foo(const T& x) { return foo<T>(x); }</code>
Dengan penjana ini, bukannya menyatakan secara jelas jenis hujah templat:
<code class="cpp">foo<int>(5);</code>
Satu boleh menggunakan keupayaan potongan fungsi penjana:
<code class="cpp">make_foo(5); // Deduces and creates foo<int>(5)</code>
Atas ialah kandungan terperinci Bolehkah Inferens Jenis Automatik Meniru Pewarisan Templat dalam C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!