容器和算法的改进 --- C++20

容器和算法的改进 — C++20

C++ 20对容器和算法有很多的改进

  • std::vectorstd::string支持constexpr
  • 所有容器支持consistent container erasure , contains
  • 新的算法移动元素 std::shift_left
  • 可以检查 std::string 的前缀和后缀

支持 constexpr 的容器和算法

  1. C++ 20std::vectorstd::string支持constexpr
  2. 超过100多种algorithm支持constexpr

这样, 你就可以实现在编译期查找字符串子串, 在编译期对数组进行排序

#include <ranges>
#include <vector>
#include <iostream>
#include <span>
#include <format>
#include <array>
#include <algorithm>consteval int maxEle()
{std::vector v{2, 4, 1, 6, 3, 8};std::sort(v.begin(), v.end());return v.back();
}consteval bool findSub(std::string s, std::string sub)
{return s.find(sub, 0) != std::string::npos;
}int main()
{constexpr int maxVal = maxEle();std::cout << maxVal << std::endl;std::cout << findSub("ianaworld", "world") << std::endl;
}

之所以能容器能在编译期能实现这些操作, 是因为使用了瞬态分配 Transient Allocation

Transient Allocation 瞬态分配

Transient Allocation: 编译期申请的内存必须在编译期就释放, 不能将编译期申请的内存在运行时使用

#include <memory>constexpr auto correctRelease()
{auto* p = new int[2020];delete [] p;return 2020;
}constexpr auto forgottenRelease()
{auto* p = new int[2020];return 2020;
}constexpr auto falseRelease()
{auto* p = new int[2020];delete p;return 2020;
}int main()
{constexpr int res1 = correctRelease();constexpr int res2 = forgottenRelease();constexpr int res3 = falseRelease();
}

image-20220618171306700

从容其中移除元素

在C++20 前是有一些复杂的

#include <algorithm>
#include <iostream>
#include <vector>int main()
{std::cout << '\n';std::vector myVec{-2, 3, -5, 10, 3, 0, -5};for (auto ele : myVec) std::cout << ele << " ";std::cout << "\n\n";std::remove_if(myVec.begin(), myVec.end(), [](int ele) { return ele < 0; });for (auto ele : myVec) std::cout << ele << " ";std::cout << "\n\n";
}

image-20220618174813249

因为没有应用新的end , 所以需要像下面这样做

#include <algorithm>
#include <iostream>
#include <vector>int main()
{std::cout << '\n';std::vector myVec{-2, 3, -5, 10, 3, 0, -5};for (auto ele : myVec) std::cout << ele << " ";std::cout << "\n\n";auto newEnd = std::remove_if(myVec.begin(), myVec.end(),[](int ele) { return ele < 0; });myVec.erase(newEnd, myVec.end());// myVec.erase(std::remove_if(myVec.begin(), myVec.end(),// [](int ele){ return ele < 0; }), myVec.end());for (auto ele : myVec) std::cout << ele << " ";std::cout << "\n\n";
}

C++ 20 之后

#include <algorithm>
#include <iostream>
#include <vector>int main()
{std::cout << '\n';std::vector myVec{-2, 3, -5, 10, 3, 0, -5};std::erase_if(myVec, [](int ele) { return ele >= 3; });for (int my_vec : myVec){std::cout << my_vec<<"  ";}
}

其他容器也类似

contains函数

可以方便的判断容器是否包含一个元素

C++ 20 之前

#include <set>
#include <iostream>int main()
{std::cout << '\n';std::set mySet{3, 2, 1};if (mySet.find(2) != mySet.end()){std::cout << "2 inside" << '\n';}std::multiset myMultiSet{3, 2, 1, 2};if (myMultiSet.count(2)){std::cout << "2 inside" << '\n';}std::cout << '\n';
}

比较长,并且对初学者不友好

C++ 20

#include <set>
#include <iostream>
#include <vector>int main()
{std::cout << std::boolalpha;std::cout << '\n';std::set mySet{3, 2, 1};std::cout << mySet.contains(2) << " ";}

这样就非常的简单了

std::shift_left/right

std::shift_left, std::shift_right - C++中文 - API参考文档 (apiref.com)

字符串前缀和后缀检查

  • starts_with
  • ends_with

Algorithms library - cppreference.com

文 - API参考文档 (apiref.com)](https://www.apiref.com/cpp-zh/cpp/algorithm/shift.html)

字符串前缀和后缀检查

  • starts_with
  • ends_with

Algorithms library - cppreference.com

std::shift_left, std::shift_right - C++中文 - API参考文档 (apiref.com)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407914.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CodeSmith基础(二)

本文将介绍CodeSmith与数据库进行交互生成相应的存储过程&#xff0c;本例使用的数据库为SQL Server 2000。 在与数据库进行交互时&#xff0c;我们使用到了一个CodeSmith自带的组件SchemaExplorer&#xff0c;利用这个组件我们可以访问数据库的数据表、存储过程、视图等…

[Android]使用ViewPager实现图片滑动展示

在淘宝等电商的APP首页经常能看到大幅的广告位&#xff0c;通常有多幅经常更新的图片用于展示促销信息&#xff0c;如下图所示&#xff1a; 通常会自动滚动&#xff0c;也可以根据手势滑动。我没有研究过人家的APP是通过什么实现的&#xff0c;可能有第三方已经封装好的控件可以…

c#获取当前应用程序所在路径

一、获取当前文件的路径1. System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName 获取模块的完整路径&#xff0c;包括文件名。2. System.Environment.CurrentDirectory 获取和设置当前目录(该进程从中启动的目录)的完全限定目录。3. System.IO.…

requires表达式 ---C++ 20 模板

requires表达式 —C 20 模板 requires还可以接一个表达式,该表达式也是一个纯右值表达式,表达式为true时满足约束条件,false则不满足约束条件 requires表达式的判定标准:对requires表达式进行模板实参的替换,如果替换之后出现无效类型,或者违反约束条件,则值为false,反之为tr…

童趣

1.豆豆的外婆买了一只母鸡&#xff0c;打算杀了吃。豆豆不允许杀它&#xff0c;外婆就把鸡养在院子里。每天早上&#xff0c;外婆在院子里干家务&#xff0c;豆豆就坐在小板凳上&#xff0c;手里拿了本小画书&#xff0c;绘声绘色地给母鸡讲故事。豆豆给母鸡起的小名是“小鸭”…

PROJECT #1 - BUFFER POOL [CMU 15-445645]笔记

PROJECT #1 - BUFFER POOL 15-445/645笔记 因为在主存中储存所有块是不可能的&#xff0c;我们需要管理主存中用于存储块的可用空间的分配 。缓冲区是主存中用于存储磁盘数据块拷贝的那部分。 缓冲区管理器 ​ 当数据库系统中的程序需要磁盘上的块时&#xff0c;它向缓冲区管…

MS SQL入门基础:系统数据库

SQL Server 2000 有四个系统数据库&#xff08;System Databases&#xff09;&#xff1a;Master、Model、Msdb、Tempdb。这些系统数据库的文件存储在Microsoft SQL Server&#xff08;默认安装目录&#xff09;的MSSQL子目录的Data 文件夹中。各系统数据库所包含的文件如表6-1…

C++20 std::jthread

C20 std::jthread std::jthread 表示 joining thread , 与C11里面的std::thread不同std::jthread 自动join, 并且可以被外部终止 自动join std::thread #include <iostream> #include <thread> using namespace std;int main(int argc, char* argv[]) {std::cou…

.NET资源收集

.NET开发资源精华收集与共享 .Net General微软.Net中文主页 .NET Framework开发中心 微软.Net Framework中文产品支持中心 微软.Net Framework中文新闻组(Web) 微软VB.Net中文新闻组(Web) 博客园 .NET 2.0 专题 孟宪会之精彩世界 微软.NET俱乐部 MSDN中文网络广播 AspxBoy教程网…

C++ 20 内存模型(一)

C 20 内存模型(一) 多线程的基础是优秀的内存模型 C20 内存模型: 高复杂性, 难以理解对多线程有更深入的理解 内存布局 位域 member_name成员名, width bit 宽度 struct bit_field_name {type member_name : width; };struct my_struct {char a;int b : 5; // 最大存储 …

C++20 Atomic 原子 内存模型(二)

C20 Atomic 原子 内存模型(二) 原子是C内存模型的基础 强/弱内存模型 1. 强内存模型 Leslie Lamport 定义了顺序一致性的概念 顺序一致性提供两个保证: 指令按源码的顺序执行对所有线程的所有指令有全局的顺序 以上不仅仅作用于原子, 也影响着非原子变量 int main(int a…

IOS设计模式之二(门面模式,装饰器模式)

本文原文请见&#xff1a;http://www.raywenderlich.com/46988/ios-design-patterns.由 krq_tiger&#xff08;http://weibo.com/xmuzyq&#xff09;翻译&#xff0c;如果你发现有什么错误&#xff0c;请与我联系谢谢。门面&#xff08;Facade&#xff09;模式&#xff08;译者…

1.使用 Blazor 利用 ASP.NET Core 生成第一个 Web 应用

参考 https://dotnet.microsoft.com/zh-cn/learn/aspnet/blazor-tutorial/create 1.使用vs2022创建新项目 选择 C# -> Windows -> Blzxor Server 应用模板 2.项目名称BlazorApp下一步 3.选择 .NET6.0 或 .NET7.0 或 .NET8.0 创建 4.运行BlazorApp 5.全部选择是。 信…

BROCADE 300和MD3200扩展柜FC SAN,截图

这表示俺玩过&#xff0c;其实&#xff0c;这个光交换机在只有一个共享存储的情况下&#xff0c;可用可不用。 FC BROCADE只是为了方便后期扩展。 FC SAN之类的识别不靠IP&#xff0c;因为不是IP SAN嘛。但也是自己的识别体系。 转载于:https://www.cnblogs.com/aguncn/p/36640…