标准库标头 <charconv>(c++17)学习

2024-09-03 00:12

本文主要是介绍标准库标头 <charconv>(c++17)学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

此头文件是strings library.

std::to_chars_result 是 std::to_chars 的返回类型。它没有基类,并且只有以下成员。

数据成员

成员名字定义

ptr

char* 类型的指针
(公开成员对象)

ec

std::errc 类型的错误码
(公开成员对象)

std::from_chars_result 是 std::from_chars 的返回类型。它没有基类,并且只有以下成员。

数据成员

成员名字定义

ptr

const char* 类型的指针
(公开成员对象)

ec

std::errc 类型的错误码
(公开成员对象)

类型声明 

namespace std {// 初等数值转换的浮点格式enum class chars_format {scientific = /* 未指定 */,fixed = /* 未指定 */,hex = /* 未指定 */,general = fixed | scientific};// 初等数值输出转换struct to_chars_result { // 独立char* ptr;errc ec;friend bool operator==(const to_chars_result&, const to_chars_result&) = default;constexpr explicit operator bool() const noexcept { return ec == errc{}; }};to_chars_result to_chars(char* first, char* last, // 独立/* integer-type */ value, int base = 10);to_chars_result to_chars(char* first, char* last, // 独立bool value, int base = 10) = delete;to_chars_result to_chars(char* first, char* last, // 独立/* floating-point-type */ value);to_chars_result to_chars(char* first, char* last, // 独立/* floating-point-type */ value, chars_format fmt);to_chars_result to_chars(char* first, char* last, // 独立/* floating-point-type */ value,chars_format fmt, int precision);// 初等数值输入转换struct from_chars_result { // 独立const char* ptr;errc ec;friend bool operator==(const from_chars_result&, const from_chars_result&) = default;constexpr explicit operator bool() const noexcept { return ec == errc{}; }};constexprfrom_chars_result from_chars(const char* first, // 独立const char* last, /* integer-type */& value,int base = 10);from_chars_result from_chars(const char* first, // 独立或被删除const char* last, /* floating-point-type */& value,chars_format fmt = chars_format::general);
}

chars_format

(C++17)

指定 std::to_chars 和 std::from_chars 所用的格式
(枚举)

from_chars_result

(C++17)

std::from_chars 的返回类型
(类)

to_chars_result

(C++17)

std::to_chars 的返回类型
(类)

函数

from_chars

(C++17)

转换字符序列到整数或浮点值
(函数)

to_chars

(C++17)

转换整数或浮点值为字符序列
(函数)

示例代码:

#include <array>
#include <charconv>
#include <iostream>
#include <string_view>
#include <system_error>
#include <cassert>
#include <iomanip>
#include <optional>//c++20
void show_to_chars(auto... format_args)
{std::array<char, 10> str;#if __cpp_lib_to_chars >= 202306L// 使用 C++26 operator bool() 进行错误检查if (auto res = std::to_chars(str.data(), str.data() + str.size(), format_args...))std::cout << std::string_view(str.data(), res.ptr) << '\n';elsestd::cout << std::make_error_code(res.ec).message() << '\n';
#elseif (auto [ptr, ec]= std::to_chars(str.data(), str.data() + str.size(), format_args...);ec == std::errc())std::cout << std::string_view(str.data(), ptr) << '\n';elsestd::cout << std::make_error_code(ec).message() << '\n';
#endif
}int main()
{//to_chars exampleshow_to_chars(42);show_to_chars(+3.14159F);show_to_chars(-3.14159, std::chars_format::fixed);show_to_chars(-3.14159, std::chars_format::scientific, 3);show_to_chars(3.1415926535, std::chars_format::fixed, 10);//form_chars examplefor (std::string_view const str : {"1234", "15 foo", "bar", " 42", "5000000000"}){std::cout << "字符串: " << std::quoted(str) << ". ";int result{};auto [ptr, ec] = std::from_chars(str.data(), str.data() + str.size(), result);if (ec == std::errc())std::cout << "结果: " << result << ", ptr -> " << std::quoted(ptr) << '\n';else if (ec == std::errc::invalid_argument)std::cout << "这不是数值。\n";else if (ec == std::errc::result_out_of_range)std::cout << "这个数值大于 int。\n";}// C++23 的 constexpr from_char 演示 / C++26 的 operator bool() 演示:auto to_int = [](std::string_view s) -> std::optional<int>{int value{};
#if __cpp_lib_to_chars >= 202306Lif (std::from_chars(s.data(), s.data() + s.size(), value))
#elseif (std::from_chars(s.data(), s.data() + s.size(), value).ec == std::errc{})
#endifreturn value;elsereturn std::nullopt;};assert(to_int("42") == 42);assert(to_int("foo") == std::nullopt);
#if __cpp_lib_constexpr_charconv and __cpp_lib_optional >= 202106static_assert(to_int("42") == 42);static_assert(to_int("foo") == std::nullopt);
#endif}

 运行结果:

参考:

标准库标头 <charconv> - cppreference.com

这篇关于标准库标头 <charconv>(c++17)学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

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 中存储指针类型的对象

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

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

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

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

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