C++11新特性(上)----《Hello C++ Wrold!》(25)--(C/C++)

C++11新特性(上)----《Hello C++ Wrold!》(25)--(C/C++)

文章目录

前言

C++ 作为一门经典且持续演进的编程语言,其标准迭代始终围绕 “提升开发效率、优化性能、完善语言特性” 展开。1998 年首个国际标准 C++98 奠定了语言基础,而 2011 年发布的 C++11 标准则堪称一次里程碑式的更新 —— 它不仅修复了早期版本的诸多缺陷,更引入了大量革命性特性,从根本上改变了 C++ 的编程范式,为开发者提供了更简洁、高效且安全的编码工具。

本文将聚焦 C++11 标准的核心新增特性,从 “统一列表初始化” 的语法简化、“auto/decltype/nullptr” 的声明优化,到 STL 容器与接口的扩展,再到 “右值引用、移动语义、完美转发” 等深刻影响性能的底层机制,以及类功能的增强(如默认移动构造、final/override 关键字),系统梳理这些特性的设计逻辑与实际应用场景。

无论是初学时对 C++11 语法的困惑,还是开发中对 “为何优先用 emplace_back 而非 push_back”“move 与 forward 该如何正确使用” 等问题的疑问,都能通过本文的拆解得到解答。文中将结合具体代码示例,区分易混淆概念(如 initializer_list 与多参数构造隐式转换、左值 / 右值与左值引用 / 右值引用),同时兼顾 “实用性” 与 “原理性”—— 既说明特性的日常用法,也点明编译器层面的特殊处理,帮助读者不仅 “会用”,更能 “理解为什么这么用”,为后续深入 C++ 高阶开发或迁移至更高版本(如 C++14/C++17)打下坚实基础。

历史知识

C++ 编程语言的第一个国际标准是1998年发布的–C++98
下面的话讲的是C++11引入的特性

除了这些,还有范围for 智能指针这些

统一的列表初始化

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

–C++11中列表初始化也可以适用于new表达式中
这个的话日常不推荐用,但是要能看得懂
比如:int y ={2};int y{2};structPoint{Point(int x,int y):_x(x),_y(y){}int _x;int _y;}; Point p1 ={1,1}; Point p1{1,1}--本来应该是Point p1(1,1); 前面这两个其实也是调用的Point的构造函数,其实是C++11支持了多参数构造函数的隐式类型转换 --如果想这两个行不通,就在构造函数前加个explicit Point* ptr3 =new Point[2]{{0,0},{1,1}};const Point& r ={3,3};--这个const去不得,因为创建一个Point临时对象(常性)

initializer_list

这是一个类型
auto 用于初始化列表 {...} 时,编译器会优先推导出 std::initializer_list<T>类型
一般容器的构造函数和赋值=都支持这个类型进行
vector<int> v1 ={1,2,3,4,3};// 调用initializer_list的vector构造函数 Point p1 ={1,1};// 多参数构造函数的隐式类型转换 这俩个要区分--不是一个规则哈 注意: 上面的{1,2,3,4,3}转换成initializer_list类型时: 其实是编译器会在常量区自动创建一个隐藏的常量数组 initializer_list 只是用指针引用这个数组,而不是自己存储数据。 --这个类型自己模拟实现不太行,库里面的这个类型编译器会做特殊照护 

声明

多了autonullptrdecltype
nullptr和NULL的区别 NULL有时直接被定义成00既能表示指针常量,又能表示整形常量 #defineNULL((void*)0) #define NULL0nullptr是空指针 引申:宏不常用的,基本上用 constenuminline去代替宏 
decltype:关键字decltype可以将变量的类型声明为表达式指定的类型 decltype推出对象的类型,再定义变量,或者作为模板实参 其实也就是eg:decltype(pf)看成一个类型去用 跟auto的区别:auto不能eg:auto x;这样不带初始化 eg:int pf =0;int a =0;double b =1.0;decltype(a*b) c =2;decltype(pf) pf2; B<decltype(pf)> bb1;//B是类 引申:函数能通过函数指针调用 eg:auto x = malloc; 之后x和malloc的用法和作用就相同了 

STL里面的一些变化

新容器

增加了arrayforward_listunordered_mapunordered_set

但是array -- 数组forward_list -- 单链表没啥用

关于数组的话:一般也用vector代替,因为原生数组容易越界之后检查不出来

新接口

对于const迭代器,给他添加了cbegincendcrbegincrend,但是这几个接口没啥用,没必要
所有的容器的构造函数都支持了initializer_list那种方式的初始化

所有的容器都支持了移动构造和移动赋值

大多数容器的很多接口都多了emplace系列的–比如以前是back 现在多了个emplace_back–并且本来的接口有些也支持了右值引用的方式

新的类功能

新增加了移动构造函数和移动赋值运算符重载

如果你没有自己实现移动构造,且没有实现析构函数 、拷贝构造、拷贝赋值重载中的任意一个,编译器会自动生成一个默认移动构造–对内置类型会浅拷贝,对自定义类型如果有移动构造就用移动构造,没有就用拷贝构造

如果你没有自己实现移动赋值重载函数,且没有实现析构函数 、拷贝构造、拷贝赋值重载中的任意一个,编译器会自动生成一个默认移动赋值–对内置类型会浅拷贝,对自定义类型如果有移动赋值就用移动赋值,没有就用拷贝赋值
允许在类定义时给成员变量初始缺省值

finaloverride
强制生成默认函数的关键字default eg:Person(Person&& p) = default;

禁止生成默认函数的关键字delete eg:Person(Person&& p) = delete;

左值引用和右值引用

左值引用是以前本来就支持的哈,右值引用还是C++11引入的

左值和右值

可以取地址的叫做左值 左值一般是可以被修改的

不能取地址的叫做右值(右值是不允许被修改的)
内置类型的右值叫做纯右值

自定义类型的右值叫做将亡值

左值引用和右值引用

左值引用就是eg: int & a = b; 粗略: 给左值取别名(b是 int b =0;)

右值引用是eg: double && r = x+y; 粗略: 给右值取别名(x y本来是double x = 1.1,y = 2.0)

注意:右值引用之后其实是让他拥有了左值的属性(有地址,并且可以被修改)
问题:

左值引用可以给右值取别名吗–const的左值引用可以eg: const int a = .....

右值引用可以给左值取别名吗-- move以后的左值可以eg: int && c = move(b);
关于这个move:拿上面举例:
voidfunc(constint& r){}voidfunc(int&& r){} 也构成函数重载哈,编译器会选择最匹配的去用 eg:传的是右值,用第二个 传的是左值,用第一个 
左值引用的核心价值就是减少拷贝,提高效率

右值引用的核心价值是进一步减少拷贝,弥补左值引用没有解决的场景,比如:传值返回

场景举例:1.自定义类型中深拷贝的类,必须传值返回时(类大的时候用,小用不用区别不大)

2.容器的插入接口,如果插入对象是右值,可以用移动构造转移资源给数据结构中的对象,也可以进一步减少拷贝

注意:浅拷贝的类只能直接拷贝,移动拷贝是不行的–因为给也给的是指针

移动构造

这个的话在出现将亡值赋值的时候会出现

这个的话就相当于把将亡值的东西给那个被赋值的,被赋值的把之前的东西给将亡值(将亡值之前存储东西的地方直接给被赋值的人了–有点像吸收别人的功力那种意思)

–只是资源被转移了哈,原来的对象还在那,不算是空对象

纯右值也会的哈,只是没啥必要而已,除非eg:vector<int>那种数组很大的
string func()//不能搞成string&或者string&&哈{ string str("xxxx");return str;} main函数里面 string s =func();--这里的话会str先深拷贝给func(),再func()移动拷贝给s --编译器优化后只有一次移动拷贝了 但是编译器会进行优化:1.连续的构造或者拷贝构造,合二为一 2.开绿灯行为:eg:这里的str直接被当成将亡值给了s eg: list<string>lt; lt.push_back("22222"); 此时也是一次移动拷贝,因为"22222"隐式转换成string的时候生成了个匿名对象(C++11的认知)--如果用的是自己模拟实现的那种string的话,生成匿名对象时还会有一次拷贝构造(现代写法)--有移动定义也是这样 
移动语义:就是用右值引用实现移动构造和移动赋值

完美转发

万能引用

万能引用的作用:既可以接收左值,又可以接受右值

实参如果是左值的话,他就是左值引用–此时是引用折叠

实参如果是右值的话,他就是右值引用

完美转发

在这里插入图片描述
补充:上面的Fun是 voidFun(int& x){}----1voidFun(constint& x){}----2voidFun(int&& x){}---3voidFun(constint&& x){}----4 调用:PerfectForward(std::move(a));PerfectForward(std::move(b)); 这俩个的话其实最后一个是用的1,一个用的2 因为Fun(t)传的时候t是右值引用--所以是左值的属性 --没用右值属性的话,在移动定义时,无法完成资源转移!!! 此时如果想保留右值引用是右值的属性的话,就要用到完美转发了 完美转发就是加个:forward<T> 也就是template<typenameT>voidPerfectForward(T&& t){Fun(forward<T>(t));}
要注意的是:如果想一直保持原来的属性,在每次传参的时候都要使用完美转发

–中间少用了一次就会永远丢失原本的属性

Read more

【django家居推荐系统】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案

【django家居推荐系统】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案

摘 要 Django家居推荐系统是一个基于Django框架开发的电子商务平台,专注于为用户提供便捷的家居购物体验。该系统不仅支持用户注册登录、浏览家居商品和资讯、收藏与购买心仪商品,还提供了详尽的商城公告和个性化的账户管理功能。通过首页展示、家居资讯推送、商品搜索及详情查看等功能模块,用户能够快速获取所需信息并完成购买决策。此外,系统的商城管理部分包括了购物车、订单、地址管理以及售后服务申请等实用功能,极大地提升了用户的购物便利性和满意度。 对于管理员而言,Django家居推荐系统提供了一个全面而强大的后台管理系统。管理员可以通过后台对商品销售数据进行监控,并对系统用户、反馈建议、轮播图、商城公告、家居资讯等进行有效管理。特别值得一提的是,系统支持对商品分类、订单、配送状态以及售后请求的细致化操作,这使得管理员可以高效地维护商城运营秩序,确保用户体验的质量。同时,管理员还能通过添加新的家居资讯、调整轮播图和发布公告等方式,持续更新网站内容,保持平台活力和吸引力。 关键词:Django框架;家居推荐系统;Python语言; Abstract The Django H

By Ne0inhk
【开源工具】超全Emoji工具箱开发实战:Python+PyQt5打造跨平台表情管理神器

【开源工具】超全Emoji工具箱开发实战:Python+PyQt5打造跨平台表情管理神器

🌟 超全Emoji工具箱开发实战:Python+PyQt5打造跨平台表情管理神器 🌈 个人主页:创客白泽 - ZEEKLOG博客 🔥 系列专栏:🐍《Python开源项目实战》 💡 热爱不止于代码,热情源自每一个灵感闪现的夜晚。愿以开源之火,点亮前行之路。 👍 如果觉得这篇文章有帮助,欢迎您一键三连,分享给更多人哦 📖 概述 在当今数字化社交时代,Emoji已成为全球通用的视觉语言。本文介绍如何使用Python和PyQt5开发一个功能全面的Emoji工具箱,包含完整的Unicode 14.0标准表情库,提供分类浏览、智能搜索和快捷复制等功能。该项目具有以下技术亮点: * 采用MVC架构设计 * 支持跨平台运行(Windows/macOS/Linux) * 实现高性能的emoji渲染和搜索 * 提供现代化的UI交互体验 * 完整包含1800+个标准emoji 🎯 功能特性 1. 全量Emoji集合 * 涵盖9大分类体系 * 每个emoji包含官方名称标注 * 支持最新Unicode 14.0标准 2. 智能搜索系统 * 支持中文

By Ne0inhk
在 CentOS 系统上实现定时执行 Python 邮件发送任务

在 CentOS 系统上实现定时执行 Python 邮件发送任务

文章目录 * **引言** * **方案一:经典基石 - Cron 作业** * **1. 原理概述** * **2. 详细实现步骤** * **3. 优缺点分析** * **4. 适用场景** * **方案二:灵活调度 - Systemd 定时器** * **1. 原理概述** * **2. 详细实现步骤** * **3. 优缺点分析** * **4. 适用场景** * **方案三:Python 内生方案 - APScheduler 库** * **1. 原理概述** * **2. 详细实现步骤** * **3. 优缺点分析** * **4. 适用场景** * **方案四:企业级任务队列 - Celery with Redis** * **1. 原理概述*

By Ne0inhk
【零基础入门】一篇掌握Python中的字典(创建、访问、修改、字典方法)【详细版】

【零基础入门】一篇掌握Python中的字典(创建、访问、修改、字典方法)【详细版】

🌈 个人主页:十二月的猫-ZEEKLOG博客 🔥 系列专栏: 🏀《PyTorch科研加速指南:即插即用式模块开发》-ZEEKLOG博客 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光  目录 1. 前言 2. 字典 2.1 字典的创建 2.1.1 大括号+直接赋值 2.1.2 大括号+字典推导式 2.1.3 dict+关键字参数 2.1.4 dict+元组列表 2.1.5 dict+zip方法 2.1.6 dict+fromkeys方法 2.2 字典的访问 2.

By Ne0inhk