C++23 新成员函数与字符串类型的改动
文章目录
- 引言
- `std::basic_string::contains` 与 `std::basic_string_view::contains` (P1679R3)
- 功能介绍
- 示例代码
- 优势
- 禁止从 `nullptr` 构造 `std::basic_string` 和 `std::basic_string_view` (P2166R1)
- 背景
- 改动
- 影响
- `std::basic_string_view` 的显式范围构造函数 (P1989R2)
- 功能介绍
- 示例代码
- 优势
- `std::basic_string::resize_and_overwrite` (P1072R10)
- 功能介绍
- 示例代码
- 优势
- 用于高效切片的 `std::basic_string::substr` 右值引用重载 (P2438R2)
- 背景
- 改动
- 示例代码
- 优势
- 总结
引言
C++ 作为一门广泛应用的编程语言,一直在不断发展和演进。C++23 作为其发展历程中的一个重要版本,引入了许多新的特性和改进,其中在字符串处理方面有一些显著的改动。这些改动不仅提升了代码的性能和效率,还增强了代码的安全性和可读性。本文将详细介绍 C++23 中几个重要的字符串相关的新特性,包括 std::basic_string::contains
与 std::basic_string_view::contains
、禁止从 nullptr
构造 std::basic_string
和 std::basic_string_view
、std::basic_string_view
的显式范围构造函数、std::basic_string::resize_and_overwrite
以及用于高效切片的 std::basic_string::substr
右值引用重载。
std::basic_string::contains
与 std::basic_string_view::contains
(P1679R3)
功能介绍
在 C++23 之前,如果要检查一个字符串是否包含另一个子字符串,通常会使用 find
函数,并检查其返回值是否不等于 npos
。例如:
#include <iostream>
#include <string>int main() {std::string str = "hello world";if (str.find("world") != std::string::npos) {std::cout << "The string contains 'world'" << std::endl;}return 0;
}
C++23 引入了 contains
函数,使得代码更加简洁和直观。std::basic_string::contains
和 std::basic_string_view::contains
提供了三个重载版本,分别用于检查字符串是否包含一个字符串视图、一个字符或一个以空字符结尾的字符串。以下是函数原型:
constexpr bool contains( std::basic_string_view<CharT,Traits> sv ) const noexcept; // (1) (since C++23)
constexpr bool contains( CharT ch ) const noexcept; // (2) (since C++23)
constexpr bool contains( const CharT* s ) const; // (3) (since C++23)
示例代码
#include <iostream>
#include <string>
#include <string_view>int main() {std::string str = "hello world";std::string_view sv = "world";if (str.contains(sv)) {std::cout << "The string contains the substring" << std::endl;}if (str.contains('o')) {std::cout << "The string contains the character 'o'" << std::endl;}if (str.contains("hello")) {std::cout << "The string contains the C-style string" << std::endl;}return 0;
}
优势
使用 contains
函数可以使代码更加清晰易懂,减少了不必要的代码量,提高了代码的可读性和可维护性。同时,由于其实现通常是内联的,性能上也不会有明显的损失。
禁止从 nullptr
构造 std::basic_string
和 std::basic_string_view
(P2166R1)
背景
在 C++23 之前,从 nullptr
构造 std::basic_string
和 std::basic_string_view
的行为是未定义的。这可能会导致程序崩溃或产生不可预期的结果。例如:
#include <iostream>
#include <string>int main() {std::string str(nullptr); // 未定义行为std::cout << str << std::endl;return 0;
}
改动
C++23 通过 P2166R1 提案,禁止了从 nullptr
构造 std::basic_string
和 std::basic_string_view
。具体来说,std::basic_string_view
的构造函数 basic_string_view( std::nullptr_t )
被删除:
basic_string_view( std::nullptr_t ) = delete; // (since C++23)
影响
这一改动提高了代码的安全性,避免了因从 nullptr
构造字符串而导致的潜在错误。如果尝试从 nullptr
构造字符串,编译器会报错,从而在编译阶段就发现问题。
std::basic_string_view
的显式范围构造函数 (P1989R2)
功能介绍
std::basic_string_view
是 C++17 引入的一个轻量级的非拥有型字符串表示,它设计用来提供对字符序列的引用。C++23 引入了显式范围构造函数,使得可以更方便地从一个范围构造 std::basic_string_view
。以下是构造函数原型:
constexpr basic_string_view() noexcept ; // (1) (since C++17)
constexpr basic_string_view( const basic_string_view& other ) noexcept = default ; // (2) (since C++17)
constexpr basic_string_view( const CharT* s, size_type count ) ; // (3) (since C++17)
constexpr basic_string_view( const CharT* s ) ; // (4) (since C++17)
template< class It, class End >
constexpr basic_string_view( It first, End last ) ; // (5) (since C++20)
template< class R >
constexpr explicit basic_string_view( R&& r ) ; // (6) (since C++23)
示例代码
#include <iostream>
#include <string>
#include <string_view>int main() {std::string str = "hello world";std::basic_string_view sv(str.begin(), str.end());std::cout << sv << std::endl;return 0;
}
优势
显式范围构造函数提供了更多的灵活性,使得可以直接从迭代器范围构造 std::basic_string_view
,而不需要先构造一个临时的字符串对象。这在处理字符串切片和子字符串时非常有用。
std::basic_string::resize_and_overwrite
(P1072R10)
功能介绍
std::basic_string::resize_and_overwrite
是 C++23 引入的一个新函数,用于调整字符串的大小并覆盖其内容。该函数接受一个最大大小和一个操作函数作为参数,操作函数用于修改字符串的内容。以下是函数原型:
template< class Operation >
constexpr void resize_and_overwrite( size_type count, Operation op );
示例代码
#include <iostream>
#include <string>int main() {std::string str = "hello";str.resize_and_overwrite(10, [](char* p, size_t count) {for (size_t i = 0; i < count; ++i) {p[i] = 'a';}return count;});std::cout << str << std::endl;return 0;
}
优势
该函数避免了在需要修改字符串内容时,先初始化一个合适大小的 std::string
的开销。它允许直接在字符串的存储上进行操作,提高了性能。
用于高效切片的 std::basic_string::substr
右值引用重载 (P2438R2)
背景
在 C++23 之前,std::basic_string::substr
函数返回一个新的 std::string
对象,这可能会导致不必要的内存分配和复制。特别是当原字符串是一个右值(临时对象)时,这种开销是可以避免的。
改动
C++23 引入了 std::basic_string::substr
的右值引用重载,允许在原字符串是右值时,直接移动其资源,而不是进行复制。这提高了切片操作的效率。
示例代码
#include <iostream>
#include <string>std::string getString() {return "hello world";
}int main() {std::string sub = getString().substr(6); std::cout << sub << std::endl; return 0;
}
优势
右值引用重载的 substr
函数在处理临时字符串时,避免了不必要的复制,提高了性能。特别是在处理大型字符串时,这种优化效果更为明显。
总结
C++23 在字符串处理方面引入的这些新特性和改动,使得代码更加简洁、安全和高效。contains
函数提高了代码的可读性,禁止从 nullptr
构造字符串增强了代码的安全性,显式范围构造函数提供了更多的灵活性,resize_and_overwrite
函数避免了不必要的初始化开销,而 substr
的右值引用重载则提高了切片操作的性能。这些改动将有助于开发者编写更加优质的 C++ 代码。
相关文章:

C++23 新成员函数与字符串类型的改动
文章目录 引言std::basic_string::contains 与 std::basic_string_view::contains (P1679R3)功能介绍示例代码优势 禁止从 nullptr 构造 std::basic_string 和 std::basic_string_view (P2166R1)背景改动影响 std::basic_string_view 的显式范围构造函数 (P1989R2)功能介绍示例…...
在 ElementUI 中实现 Table 单元格合并
在 ElementUI 中实现 Table 单元格合并 在使用 ElementUI 的 Table 组件时,有时我们需要合并相邻的单元格,以提高表格的可读性和简洁性。下面是一个关于如何在 Table 中根据特定字段合并单元格的实现方法。 逻辑分析 spanMethod 方法:这是 …...

threejs渲染器和前端UI界面
1. three.js Canvas画布布局 学习本节课之前,可以先回顾下第一章节入门部分的6和12两小节关于threejs Canvas画布布局的讲解。 网页上局部特定尺寸:1.6 第一个3D案例—渲染器(opens new window) 全屏,随窗口变化:1.12 Canvas画布布局和全屏…...

AI笔记 - 网络模型 - mobileNet
网络模型 mobileNet mobileNet V1网络结构深度可分离卷积空间可分 参考 mobileNet V1 网络结构 MobileNetV1可以理解为VGG中的标准卷积层换成深度可分离卷积 可分离卷积主要有…...

day12 leetcode-hot100-20(矩阵3)
48. 旋转图像 - 力扣(LeetCode) 1.辅助数组法(题目不让) 思路:很简单,新建一个二维数组,直接找新数组与旧数组的规律即可。比如这个旋转90。那就是相当于 new[col][n-row-1]old[row][col],然后…...

【Java开发日记】基于 Spring Cloud 的微服务架构分析
目录 1、Spring Cloud 2、Spring Cloud 的核心组件 1. Eureka(注册中心) 2. Zuul(服务网关) 3. Ribbon(负载均衡) 4. Hystrix(熔断保护器) 5. Feign(REST转换器&a…...
接口性能优化
一、耗时统计 在做接口的性能优化时,最重要的是知道时间消耗在哪里。 可以用StopWatch,进行耗时统计。 详情见: https://blog.csdn.net/sinat_32502451/article/details/148350451 二、链路追踪 如果团队使用了Skywalking,可以…...

AWTK 嵌入式Linux平台实现多点触控缩放旋转以及触点丢点问题解决
前言 最近涉及海图的功能交互,多点触摸又开始找麻烦。 在PC/Web平台awtk是通过底层的sdl2库来实现多点触摸,但是在嵌入式Linux平台,可能是考虑到性能原因,awtk并没有采用sdl库来做事件处理,而是自己实现一个awtk-lin…...

尚硅谷redis7 93-97 springboot整合reids之总体概述
93 springboot整合reids之总体概述 总体概述 jedis-lettuce-RedisTemplate三者的联系 名称类型作用描述和其它的关系JedisRedis 客户端早期主流的 Java Redis 客户端,基于阻塞 I/O,同步操作可作为 RedisTemplate 的底层连接实现LettuceRedis 客户端基…...
Flutter、React Native、Unity 下的 iOS 性能与调试实践:兼容性挑战与应对策略(含 KeyMob 工具经验)
移动端跨平台开发逐渐成为常态,Flutter、React Native、Unity、Hybrid App 等框架在各类 iOS 项目中频繁出现。但随之而来的,是一系列在 iOS 设备上调试难、性能数据采集难、日志整合难的问题。 今天这篇文章,我从实际项目出发,聊…...

声纹技术体系:从理论基础到工程实践的完整技术架构
文章目录 一、声纹技术的理论基础与概念内核1.1 声纹的生物学本质与数学表征1.2 特征提取的理论基础与实现机制 二、声纹识别技术的演进逻辑与方法体系2.1 传统统计学方法的理论架构2.2 深度学习方法的技术革新2.3 损失函数的设计原理与优化策略 三、声纹识别系统的架构设计与模…...

行为型:命令模式
目录 1、核心思想 2、实现方式 2.1 模式结构 2.2 实现案例 3、优缺点分析 4、适用场景 5、实际应用 1、核心思想 目的:将指令信息封装成一个对象,并将此对象作为参数发送给接收方去执行,以使命令的请求方与执行方解耦 概念ÿ…...
构建多模型协同的Ollama智能对话系统
构建多模型协同的Ollama智能对话系统 在人工智能应用中,单一模型往往难以满足复杂场景的需求。本文将介绍如何整合多个Ollama模型,构建一个智能对话系统,实现情感分析、危机评估和智能回复的协同功能。 系统架构 该系统采用多模型pipeline…...

vue3 + WebSocket + Node 搭建前后端分离项目 开箱即用
[TOC](vue3 WebSocket Node 搭建前后端分离项目) 开箱即用 前言 top1:vue3.5搭建前端H5 top2:Node.js koa搭建后端服务接口 top3:WebSocket 长连接实现用户在线聊天 top4:接口实现模块化 Mysql 自定义 top5:文件上…...

Win10秘笈:两种方式修改网卡物理地址(MAC)
Win10秘笈:两种方式修改网卡物理地址(MAC) 在修改之前,可以先确定一下要修改的网卡MAC地址,查询方法有很多种,比如: 1、在设置→网络和Internet→WLAN/以太网,如下图所示。 2、在控…...

【软件】navicat 官方免费版
Navicat Premium Lite https://www.navicat.com.cn/download/navicat-premium-lite...

【深度学习】16. Deep Generative Models:生成对抗网络(GAN)
Deep Generative Models:生成对抗网络(GAN) 什么是生成建模(Generative Modeling) 生成模型的主要目标是从数据中学习其分布,从而具备“生成”数据的能力。两个关键任务: 密度估计࿰…...
java操作服务器文件(把解析过的文件迁移到历史文件夹地下)
第一步导出依赖 <dependency><groupId>org.apache.sshd</groupId><artifactId>sshd-core</artifactId><version>2.13.0</version></dependency> 第二步写代码 public void moveFile( List<HmAnalysisFiles> hmAnalys…...

特伦斯 S75 电钢琴:重构演奏美学的极致表达
在数字音乐时代,电钢琴正从功能性乐器升级为融合艺术、科技与生活的美学载体。特伦斯 S75 电钢琴以极简主义哲学重构产品设计,将专业级演奏体验与现代家居美学深度融合,为音乐爱好者打造跨越技术边界的沉浸式艺术空间。 一、极简主义的视觉叙…...
STM32-标准库-GPIO-API函数
1.void GPIO_DeInit(GPIO_TypeDef* GPIOx); 简明 清除GPIOx的外围寄存器下所有引脚的配置, 恢复到默认配置状态(即上电初始值) 参数 GPIOx:其中x可以是(A..G)来选择GPIO外设。 返回值 None void GPIO_DeInit(GPI…...

Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作
Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作 文章目录 Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作观前提醒:1. Java中操作文件的简单介…...
机器学习与深度学习06-决策树02
目录 前文回顾5.决策树中的熵和信息增益6.什么是基尼不纯度7.决策树与回归问题8.随机森林是什么 前文回顾 上一篇文章地址:链接 5.决策树中的熵和信息增益 熵和信息增益是在决策树中用于特征选择的重要概念,它们帮助选择最佳特征进行划分。 熵&#…...
Netty 实战篇:构建简易注册中心,实现服务发现与调用路由
本文将为前面构建的轻量级 RPC 框架添加“服务注册与发现”功能,支持多服务节点动态上线、自动感知与调用路由,为构建真正可扩展的分布式系统打好基础。 一、背景:为什么需要注册中心? 如果每个客户端都硬编码连接某个 IP/端口的…...
微信小程序(uniapp)对接腾讯云IM
UniApp 对接腾讯云 IM(即时通讯)完整指南 一、项目背景与需求分析 随着社交场景的普及,即时通讯功能已成为移动应用的标配。腾讯云 IM(Tencent IM,即 TIM)提供稳定可靠的即时通讯服务,支持单聊…...

使用摄像头推流+VLC软件拉流
一、作用 使用摄像头创建rtsp链接,并使用VLC软件拉流显示。 二、步骤 1、安装FFmpeg库 下载地址:https://ffmpeg.org/download.htmlFFmpeg库的下载参考之前的博客,下载Win64版本即可:https://blog.csdn.net/beijixingcd/artic…...
python魔法函数
Python 中的魔法方法(Magic Methods),也称为特殊方法(Special Methods)或双下方法(Dunder Methods),是以双下划线 __ 开头和结尾的方法。它们用于定义类的行为,例如运算符…...

XCUITest 是什么
XCUITest(全称 Xcode UI Test)是苹果官方提供的 iOS/macOS UI 自动化测试框架,集成在 Xcode 开发工具中,专门用于测试 Swift/Objective-C 开发的应用程序。 1. XCUITest 的核心特点 ✅ 官方支持:苹果原生框架…...
使用k8s服务进行端口代理
创建registry-service.yaml 使用无Selector的Service Endpoints模式 vi registry-service.yaml编辑以下内容 apiVersion: v1 kind: Service metadata:name: registry-service spec:type: NodePortports:- name: httpprotocol: TCPport: 81 # Service内部端口targ…...

灌水论坛系统总体设计文档
一、实验题目 灌水论坛系统 二、实验目的 旨在通过一个相对完整且功能丰富的Web应用实例,全面地实践和巩固Web开发所需的各项核心技术和工程方法,从而提升其综合应用能力和解决实际开发问题的能力。它不仅仅是完成一个软件,更是一个学习、…...

Mac M1编译OpenCV获取libopencv_java490.dylib文件
Window OpenCV下载地址 https://opencv.org/releases/OpenCV源码下载 https://github.com/opencv/opencv/tree/4.9.0 https://github.com/opencv/opencv_contrib/tree/4.9.0OpenCV依赖 brew install libjpeg libpng libtiff cmake3 ant freetype构建open CV cmake -G Ninja…...