c++11 初始化列表 std::initializer_list

2024-03-06 18:38

本文主要是介绍c++11 初始化列表 std::initializer_list,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

c++11 初始化列表 std::initializer_list

#include <iostream>
#include <vector>
#include <map>// 使用 std::initializer_list<int> 来初始化任意长度的初始化列表
//stl中的容器是通过使用 std::initializer_list 完成的
class Foo
{
public:Foo(std::initializer_list <int>) {}
};class FooVector
{std::vector<int> content_;public:FooVector(std::initializer_list<int> list)//initializer_list 负责接收初始化列表{for (auto it = list.begin(); it != list.end(); ++it){content_.push_back(*it);}}
};//map 是以 pair形式插入的。map中的元素的类型value_type 
//typedef pair<const Key, Type> value_type;class FooMap
{std::map<int, int> content_;//using + 别名 = 包括详细命名空间信息的具体的类型。using pair_t = std::map<int, int>::value_type;//重新命名类型   typedefpublic:FooMap(std::initializer_list<pair_t> list){for (auto it = list.begin(); it != list.end(); ++it){content_.insert(*it);}}
};//使用 std::initializer_list 给自定义类型做初始化
void test01()
{Foo foo = { 1,2,3,4,5 };FooVector foo1 = { 1, 2, 3, 4, 5 };FooMap foo2 = { { 1, 2 }, { 3, 4 }, { 5, 6 } };
}//使用 std::initializer_list 传递同类型的数据
void func(std::initializer_list<int> list)
{std::cout << "size = " << list.size() << std::endl;//对 std::initializer_list 访问只能通过begin() end() 循环遍历//迭代器是只读的,无法修改某一个元素,但可以整体赋值for (auto it = list.begin(); it != list.end(); it++){std::cout << *it << std::endl;}
}void test02()
{func({});//1个空集合func({ 1,2,3 });//传递 { 1,2,3 }
}/*std::initializer_list 的内部并不负责保存初始化列表中元素的拷贝,仅仅存储了列表中元素的引用而已,因此需要再持有对象的生存周期之前传递完毕
*///错误的使用方法
std::initializer_list<int> func2(void)
{int a = 1, b = 2;return { a,b };//ab 返回时并没有拷贝
}//正确的使用
std::vector<int> func3(void)
{int a = 1, b = 2;return { a,b };//
}void test03()
{std::initializer_list<int> myList;size_t n = myList.size();myList = { 1,2,3,4,5,6 };n = myList.size();std::cout << "n="<<n << std::endl;myList = { 11,22 };n = myList.size();std::cout <<"n="<< n << std::endl;std::vector<int> a;a = func2();//值时乱码值for (auto it = a.begin(); it != a.end(); it++) {std::cout << *it << " ";}std::cout<<std::endl;a = func3();for (auto it = a.begin(); it != a.end(); it++) {std::cout << *it << " ";}std::cout << std::endl;}int main(void)
{test01();test02();test03();system("pause");return 0;
}
输出:
size = 0
size = 3
1
2
3
n=6
n=2
389674272 125
1 2

这篇关于c++11 初始化列表 std::initializer_list的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/780965

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Python进阶之列表推导式的10个核心技巧

《Python进阶之列表推导式的10个核心技巧》在Python编程中,列表推导式(ListComprehension)是提升代码效率的瑞士军刀,本文将通过真实场景案例,揭示列表推导式的进阶用法,希望对... 目录一、基础语法重构:理解推导式的底层逻辑二、嵌套循环:破解多维数据处理难题三、条件表达式:实现分支

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用