C++ 初始化
考慮如下代碼:
int main(){int x = 1;//int y = (1); //無(wú)用int z = { 1 };int a; //沒(méi)有初始化器,不考慮int b(1);int c{ 1 };}眼花繚亂的初始化語(yǔ)法。帶初始化器的,基本就是:=1? ?(1)? ?={1} 或 {1} 這幾種情況。變量名字和初始化器的分隔符是:=? ()? {}這三種
#include <iostream>class S { public:S(std::initializer_list<int> il) {std::cout << "S(std::initializer_list<int> il) called" << std::endl;}S(int i) {std::cout << "S(int i) called" << std::endl;} };int main(){S y = 1;S z = { 1 };S a(1);S b{ 1 }; }我們發(fā)現(xiàn),對(duì)于用戶定義類型,具有{} 初始化器的,優(yōu)先匹配S(std::initializer_list<int> il)。這給人提了個(gè)醒,{}不是那么萬(wàn)能的初始化語(yǔ)法。如果想調(diào)用S(int)這個(gè)構(gòu)造函數(shù),還是要老實(shí)的用傳統(tǒng)的S a(1)語(yǔ)法。
#include <boost/type_index.hpp> #include <iostream>int main() {auto x = (1);auto y = 1;auto z = { 1 };auto a(1);auto b{ 1 };using boost::typeindex::type_id_with_cvr;std::cout << type_id_with_cvr< decltype(x)>().pretty_name() << '\n';std::cout << type_id_with_cvr< decltype(y)>().pretty_name() << '\n';std::cout << type_id_with_cvr< decltype(z)>().pretty_name() << '\n';std::cout << type_id_with_cvr< decltype(a)>().pretty_name() << '\n';std::cout << type_id_with_cvr< decltype(b)>().pretty_name() << '\n'; }auto使用另外的規(guī)則,={1} 會(huì)推導(dǎo)成std::initializer_list<int>{1}? 而{1}會(huì)推導(dǎo)成 (int)1
總結(jié):基本類型int:? ?={1}? ? {1}? 推導(dǎo)成 (int)1? ??
? ? ? ? ? ?自定義類型:? ?={1}? ? {1}??推導(dǎo)成std::initializer_list<int>{1}? ? ? 注:前提是自定義類型構(gòu)造函數(shù)有std::initializer_list為參數(shù)的構(gòu)造函數(shù),就像S定義的那樣。
? ? ? ? ? ?auto的情況:? ?={1}? ? ?推導(dǎo)成std::initializer_list<int>{1}?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?{1}? ? ?推導(dǎo)成(int)1
規(guī)則還是比較復(fù)雜難記的,所以遇到{}初始化器還是小心為妙。
轉(zhuǎn)載于:https://www.cnblogs.com/thomas76/p/8594576.html
總結(jié)
- 上一篇: 核桃补脑和深度学习
- 下一篇: swoole安装全纪录