【C++11】常用新语法①(统一的列表初始化 || initializer_list || 声明 || STL新增容器 || 右值引用和移动语义 || 万能引用和完美转发)

【C++11】常用新语法①(统一的列表初始化 || initializer_list || 声明 || STL新增容器 || 右值引用和移动语义 || 万能引用和完美转发)
在这里插入图片描述

🔥个人主页:Forcible Bug Maker
🔥专栏:C++

目录

🌈前言

本篇博客主要内容:C++11的简介,以及其中较为常用的新语法。

之前部分内容都是基于C++98来进行展开的,在最开始几节语法的基础上自实现STL库中的容器,完善容器的过程中逐渐培养起C++的编程思维。C++11的一些新语法可能会对传统C++98的选手们产生一定的冲击,毕竟新语法就是一种新玩法,建议提前做好心理准备,开始本次的内容。

🔥C++11简介

在2003年C++标准委员会曾经提交了一份计数勘误表(简称TC1),使得C++03这个名字取代C++98称为C++11之前的最新C++标准名称。不过由于C++03(TC1)主要时对C++98标准中的漏洞进行修复,语言的核心部分则没有改动,因此人们习惯性的把两个标准合并称为C++98/03标准。从C++0x到C++11,C++标准十年磨一剑,第二个真正意义上的标准姗姗来迟。相比于C++98/03,C++11带来了数量可观的变化,其中包含了约140个新特性,以及对C++03标准中约600个缺陷的修正,这使得C++11更像是从C++98/03中孕育出的一种新语言。相比较而言,C++11能更好地用于系统开发和库开发、语法更加泛华和简单化、更加稳定和安全,不仅功能更强大,而且能提升程序员的开发效率,公司实际项目开发中也用得比较多,所以要作为一个重点去学习。C++11增加的语法特性非常篇幅非常多,我们这里没办法一一讲解,所以博客中主要讲解实际中比较实用的语法。
C++11的官方介绍文档

🔥统一的列表初始化({}初始化)

C++98中,标准允许使用花括号{}对数组或者结构体元素进行统一的列表初始值设定。如:

structPoint{ int _x;int _y;};intmain(){ int array1[]={ 1,2,3,4,5};int array2[5]={ 0}; Point p ={ 1,2};return0;}

C++11扩大了用大括号括起的列表(初始化列表)的使用范围,使其可用于所有的内置类型和用户的自定义类型,使用初始化列表时可添加等号(=),也可不添加

structPoint{ int _x;int _y;};intmain(){ int x1 =1;int x2{ 2};int array1[]{ 1,2,3,4,5};int array2[5]{ 0}; Point p{ 1,2};// C++11中列表初始化也可以适用于new表达式中int* pa =newint[4]{ 0};return0;}

创建对象时也可以使用列表初始化方式调用构造函数初始化:

classDate{ public:Date(int year,int month,int day):_year(year),_month(month),_day(day){  cout <<"Date(int year, int month, int day)"<< endl;}private:int _year;int _month;int _day;};intmain(){  Date d1(2022,1,1);// old style// C++11支持的列表初始化,这里会调用构造函数初始化 Date d2{ 2022,1,2}; Date d3 ={ 2022,1,3};return0;}
在这里插入图片描述

🔥std::initializer_list

在这里插入图片描述


介绍文档地址:戳这里~
std::initializer_list的类型:

intmain(){ // the type of il is an initializer_listauto il ={ 10,20,30}; cout <<typeid(il).name()<< endl;return0;}
在这里插入图片描述


std::initializer_list的使用场景:
std::initializer_list一般是作为构造函数的参数,C++11对STL中的不少容器就增加std::initializer_list作为参数的构造函数,这样就能便于初始化对象。也可以作为operator=的参数,从而允许用大括号赋值。

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述
intmain(){  vector<int> vt ={ 1,2,3,4,<

Read more

Flutter 三方库 posix 的鸿蒙化适配指南 - 掌控底层系统调用、文件权限管理实战、鸿蒙级系统级工具专家

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 posix 的鸿蒙化适配指南 - 掌控底层系统调用、文件权限管理实战、鸿蒙级系统级工具专家 在鸿蒙跨平台应用开发中,当我们需要实现精密的文件权限操控(如 chmod)、获取系统级用户信息或是管理进程间的信号(Signals)时,高层的 Dart SDK 有时无法提供足够细粒度的控制。如果你需要一种接近 C 语言、直接与鸿蒙内核(Kernel)对话的能力。今天我们要深度解析的 posix——一个旨在为 Dart 提供标准可移植操作系统接口(POSIX)支持的高性能库,正是帮你接管“系统底层主权”的关键插件。 前言 posix 是一套对底层 C 库函数的轻量级封装。它通过 Dart FFI 机制,让你能像写

By Ne0inhk
Flutter for OpenHarmony:lpinyin 汉字转拼音的高效方案(通讯录排序与搜索优化) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:lpinyin 汉字转拼音的高效方案(通讯录排序与搜索优化) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在开发中文应用时,汉字转拼音是一个绕不开的高频需求。 最典型的场景包括: * 通讯录排序:将“张三”排在 ‘Z’ 组,将“李四”排在 ‘L’ 组。 * 拼音搜索:用户输入 “wx” 就能搜到 “微信” (Weixin)。 lpinyin 是 Dart 社区中广泛使用的一个汉字转拼音库。它基于庞大的字典库,支持多音字处理、声调转换,且性能优秀。 对于 OpenHarmony 应用,由于系统底层 API(如 Intl)对中文拼音的支持可能存在差异或版本限制,引入一个纯 Dart 实现的拼音库能保证跨平台行为的一致性,确保你的鸿蒙应用在处理中文数据时准确无误。 一、核心原理 lpinyin 的工作原理非常直观:

By Ne0inhk
Flutter for OpenHarmony:kiwi 极简依赖注入容器,解耦神器(减少样板代码的 DI 库) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:kiwi 极简依赖注入容器,解耦神器(减少样板代码的 DI 库) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在构建大型 Flutter 应用时,依赖注入 (Dependency Injection, DI) 是绕不开的话题。 * ViewModel 依赖 Service。 * Service 依赖 Repository。 * Repository 依赖 HttpClient 和 Database。 如果全靠手动 new 和传参,代码会变成一团乱麻(Dependency Hell)。 Flutter 社区有很多 DI 解决方案,如 Provider, GetIt, Riverpod。而 Kiwi 是一个非常轻量级且强大的选择。它最大的特点是支持 代码生成 (Code Generation),这大大减少了手写注册代码的工作量,并且在编译时就能发现依赖错误,而不是等到运行时崩给你看。 对于

By Ne0inhk
【Linux系列】打造你的数字车间:Linux 基础开发工具入门与精要 — gcc/g++ 编译

【Linux系列】打造你的数字车间:Linux 基础开发工具入门与精要 — gcc/g++ 编译

🫧 励志不掉头发的内向程序员:个人主页  ✨️ 个人专栏: 《C++语言》《Linux学习》 🌅偶尔悲伤,偶尔被幸福所完善 👓️博主简介: 文章目录 * 前言 * 一、编译流程 * 二、gcc 编译 * 2.1、直接生成可执行程序的 2 种方式 * 2.2、gcc 编译选项 * 预处理(进行宏替换) * 编译(生成汇编) * 汇编(生成机器可识别代码) * 连接(生成可执行文件或库文件) * 三、g++ 编译 * 四、静态库和动态库 * 五、动态链接和静态链接 * 总结 前言 上一章节讲解了 vim 编辑器,但是还没有说明我们的文件怎么编译成可执行文件,本章节我们便来讲解说明,这也是一个非常重要的内容,我们一起来看看吧。 一、

By Ne0inhk