std::initializer_list in C++0x
作者:唐風(fēng)
原載:www.shnenglu.com/liyiwen
轉(zhuǎn)載請注明出處
在VC2010中,在語言核心方面增加了五個(gè)C++0x的特性:lambda、auto、static_assert、decltype、rvalue。
有點(diǎn)遺憾的是沒有 std::initializer_list(其實(shí)遺憾的還有很多,只怪C++0x來得太晚,呵呵)。
std::initializer_list 帶來的方便性是不言而喻的,它可以讓標(biāo)準(zhǔn)容器庫的使用變得更加的方便:
在以前,我們使用一個(gè)容器,只能這樣做:
int a[] = {0, 1, 2, 3};
std::vector<int> vec(a, a+sizeof(a));
或是:
std::vector<int> vec;
vec.push_back(1);
vec.push_back(3);
vec.push_back(3);
vec.push_back(2);
這樣很不美觀,也很不方便,如果要初始化的值很多,就會(huì)拖得很長,當(dāng)嵌套使用容器類的時(shí)候就更麻煩了。這也使得容器對象在做 const 值使用時(shí)非常不方便,因?yàn)樗某跏蓟艹蓡栴}。
C++0x 中加入了 std::initializer 之后,這一問題就可以得到解決。
我們以后可以這樣寫:
std::vector<int> vec = {0, 2, 3, 5};
統(tǒng)一又很簡潔。贊?。ㄔ缇蛻?yīng)該這樣了!呵呵)
假設(shè)我有一個(gè)類,其中有需要一個(gè)“查詢器”,根據(jù)不同人的名字得到生日(字符串),我們可以這么寫:
class Test {

private:
static std::map<string, string> const nameToBirthday = {
{"lisi", "18841011"},
{"zhangsan", "18850123"},
{"wangwu", "18870908"},
{"zhaoliu", "18810316"},
};
}
這樣,這個(gè)對象的聲明和定義都在一起,非常清晰,寫法也簡單。在成員函數(shù)中可以直接使用這個(gè) map 的對象來進(jìn)行查詢。如果在 C++98/03 ,要實(shí)現(xiàn)這個(gè)就要麻煩很多。
注意,結(jié)合 C++0x 中新增的初始化方法,以后就算不是 static const 的成員也可以用這樣的初始化形式了。
這種初始化語法的是依靠使用 std::initializer_list<T> 類來實(shí)現(xiàn)的。
比如 vector ,會(huì)提供這樣的一個(gè)構(gòu)造函數(shù):
template <typename T>
vector::vector(std::initializer_list<T> initList);
這個(gè) std::initializer_list<T> 類也像 STL 容器類一樣,也提供迭代器,可以遍歷其中的內(nèi)容。
但與普通的容器類不一樣的是,這個(gè)類是“一等公民”(first-class),由只能用{}這個(gè)語法進(jìn)行初始化,而且只能由編譯器來構(gòu)建。構(gòu)建成功就不能再改變(像 const ,呵呵),可以拷貝它,但所有拷貝實(shí)質(zhì)上都是以引用方式進(jìn)行的。
由于 std::initializer_list 是一個(gè)類,所以不局限在構(gòu)造函數(shù)中使用,普通的函數(shù)也可以使用,像這樣:
void DealWithAll(std::initializer_list<int> intList) {
for (auto i: intList) { // print all number
cout<<i<<endl;
}
unsigned int count = 0;
// count for the odd numbers in the list, you can use std::count too.
for_each (intList.begin(), intList.end(), [&count](int& a) {
if (a % 2) {
++count;
}
})
}
int main(void) {
DealWithAll({1,2,3,4,5,6,7,8,9}); // you can call DealWithAll like this.
}
PS:
呵呵,寫來寫去,發(fā)現(xiàn) C++0x 反而越來越不像 C 了,嗯,也確實(shí)不需要太像 C ,C++ 就是 C++ ,希望 C++0x 能給 C++ 帶來新的生命力。