C++中的std::initializer_list使用解讀
C++中的std::initializer_list
initializer_list是C++11提供的一種新類型,其定義于頭文件<initializer_list>中,此頭文件是工具庫的一部分,
<initializer_list>定義如下:
namespace std {
template<class E> class initializer_list {
public:
using value_type = E;
using reference = const E&;
using const_reference = const E&;
using size_type = size_t;
using iterator = const E*;
using const_iterator = const E*;
constexpr initializer_list() noexcept;
constexpr size_t size() const noexcept; // 元素?cái)?shù)量
constexpr const E* begin() const noexcept; // 首元素
constexpr const E* end() const noexcept; // 末元素后一位置
};
// initializer_list 范圍訪問
template<class E> constexpr const E* begin(initializer_list<E> il) noexcept;
template<class E> constexpr const E* end(initializer_list<E> il) noexcept;
}std::initializer_list 類型對(duì)象是一個(gè)訪問 const T 類型對(duì)象數(shù)組的輕量代理對(duì)象。
std::initializer_list 對(duì)象在這些時(shí)候自動(dòng)構(gòu)造:
- 用花括號(hào)初始化器列表列表初始化一個(gè)對(duì)象,其中對(duì)應(yīng)構(gòu)造函數(shù)接受一個(gè)std::initializer_list 參數(shù)
- 以花括號(hào)初始化器列表為賦值的右運(yùn)算數(shù),或函數(shù)調(diào)用參數(shù),而對(duì)應(yīng)的賦值運(yùn)算符/函數(shù)接受 std::initializer_list 參數(shù)
- 綁定花括號(hào)初始化器列表到 auto ,包括在范圍 for 循環(huán)中
initializer_list 可由一對(duì)指針或指針與其長(zhǎng)度實(shí)現(xiàn)。復(fù)制一個(gè) std::initializer_list 不會(huì)復(fù)制其底層對(duì)象。
底層數(shù)組不保證在原始 initializer_list 對(duì)象的生存期結(jié)束后繼續(xù)存在。 std::initializer_list 的存儲(chǔ)是未指定的(即它可以是自動(dòng)、臨時(shí)或靜態(tài)只讀內(nèi)存,依賴場(chǎng)合)。 (C++14 前)
底層數(shù)組是 const T[N] 類型的臨時(shí)數(shù)組,其中每個(gè)元素都從原始初始化器列表的對(duì)應(yīng)元素復(fù)制初始化(除非窄化轉(zhuǎn)換非法)。底層數(shù)組的生存期與任何其他臨時(shí)對(duì)象相同,除了從數(shù)組初始化 initializer_list 對(duì)象會(huì)延長(zhǎng)數(shù)組的生存期,恰如綁定引用到臨時(shí)量(有例外,例如對(duì)于初始化非靜態(tài)類成員)。底層數(shù)組可以分配在只讀內(nèi)存。 (C++14 起)
若聲明了 std::initializer_list 的顯式或偏特化則程序?yàn)椴∈健?/p>
1.成員類型
| 成員類型 | 定義 |
|---|---|
| value_type | T |
| reference | const T& |
| const_reference | const T& |
| size_type | std_size_t |
| iterator | const T* |
| const_iterator | const T* |
2.成員函數(shù)
構(gòu)造函數(shù)
| initializer_list() noexcept; | (C++11 起) (C++14 前) |
|---|---|
| constexpr initializer_list() noexcept; | (C++14 起) |
#include <iostream>
#include <initializer_list>
int main(){
std::initializer_list<int> empty_list;
std::cout << "empty_list.size(): " << empty_list.size() << '\n';
// 用列表初始化創(chuàng)建初始化器列表
std::initializer_list<int> digits {1, 2, 3, 4, 5};
std::cout << "digits.size(): " << digits.size() << '\n';
// auto 的特殊規(guī)則表示‘ fraction '擁有類型
// type std::initializer_list<double>
auto fractions = {3.14159, 2.71828};
std::cout << "fractions.size(): " << fractions.size() << '\n';
}結(jié)果如下:

- size :返回initializer_list中元素?cái)?shù)目
- begin:返回指向首元素的指針
- end:返回指向末尾元素后一位置的指針
3.非成員函數(shù)
| std::begin(std::initializer_list) (C++11) | 特化 std::begin |
|---|---|
| std::end(std::initializer_list)(C++11) 定義于頭文件 | 特化std::end |
| rbegin(std::initializer_list) (C++14) | 特化std::rbegin |
| rend(std::initializer_list)(C++14) | 特化std::rend |
#include <iostream>
#include <vector>
#include <initializer_list>
template <class T>
struct S {
std::vector<T> v;
S(std::initializer_list<T> l) : v(l) {
std::cout << "constructed with a " << l.size() << "-element list\n";
}
void append(std::initializer_list<T> l) {
v.insert(v.end(), l.begin(), l.end());
}
std::pair<const T*, std::size_t> c_arr() const {
return {&v[0], v.size()}; // 在 return 語句中復(fù)制列表初始化
// 這不使用 std::initializer_list
}
};
template <typename T>
void templated_fn(T) {}
int main(){
S<int> s = {1, 2, 3, 4, 5}; // 復(fù)制初始化
s.append({6, 7, 8}); // 函數(shù)調(diào)用中的列表初始化
std::cout << "The vector size is now " << s.c_arr().second << " ints:\n";
for (auto n : s.v)
std::cout << n << ' ';
std::cout << '\n';
std::cout << "Range-for over brace-init-list: \n";
for (int x : {-1, -2, -3}) // auto 的規(guī)則令此帶范圍 for 工作
std::cout << x << ' ';
std::cout << '\n';
auto al = {10, 11, 12}; // auto 的特殊規(guī)則
std::cout << "The list bound to auto has size() = " << al.size() << '\n';
// templated_fn({1, 2, 3}); // 編譯錯(cuò)誤!“ {1, 2, 3} ”不是表達(dá)式,
// 它無類型,故 T 無法推導(dǎo)
templated_fn<std::initializer_list<int>>({1, 2, 3}); // OK
templated_fn<std::vector<int>>({1, 2, 3}); // 也 OK
}結(jié)果如下:

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C++條件及循環(huán)語句的綜合運(yùn)用實(shí)例
這篇文章主要介紹了C++條件及循環(huán)語句的綜合運(yùn)用實(shí)例,能夠幫助C++初學(xué)者更好地掌握C++的邏輯語句用法,需要的朋友可以參考下2015-09-09
C++JSON庫CJsonObject詳解(輕量簡(jiǎn)單好用)
CJsonObject是基于cJSON全新開發(fā)一個(gè)C++版的JSON庫,CJsonObject的最大優(yōu)勢(shì)是輕量簡(jiǎn)單好用,開發(fā)效率極高,對(duì)多層嵌套json的讀取和生成使用非常簡(jiǎn)單,喜歡的朋友一起看看吧2021-04-04
關(guān)于C++中數(shù)據(jù)16進(jìn)制輸出的方法
本文主要介紹了關(guān)于C++中數(shù)據(jù)16進(jìn)制輸出的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
C語言詳解關(guān)鍵字sizeof與unsigned及signed的用法
這篇文章主要為大家詳細(xì)介紹了C語言關(guān)鍵字sizeof&&unsigned&&signed,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
C++實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03

