【BOOST程序库】对字符串的处理
基本概念这里不解释了,代码中详细解释了BOOST程序库中对于字符串每一个方法的详细用法:
注意:这里每实践一个方法,都将上面实践过的方法进行了注释,如果全部取消注释,会出现重命名的问题。
#include <iostream>
#include <string>//boost类型转换头文件
#include <boost/lexical_cast.hpp>
//boost格式化字符头文件
#include <boost/format.hpp>
//boost轻量化字符串头文件
#include <boost/utility/string_ref.hpp>
//字符串算法头文件
#include <boost/algorithm/string.hpp>int main() {/*//C++自带的字符串转换:int ivalue = std::stoi("42");int lvalue = std::stol("122");long long llvalue = std::stoll("42222");double dbvalue = std::stod("42.222");std::string szStr = std::to_string(12138);std::cout << typeid(ivalue).name() << "\t" << typeid(lvalue).name() << "\t" << typeid(llvalue).name() << "\t" << typeid(dbvalue).name() << "\t" << typeid(szStr).name() << std::endl;std::cout << ivalue << "\t" << lvalue << "\t" << llvalue << "\t" << dbvalue << "\t" << szStr << std::endl;//输出:int int __int64 double class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >//42 122 42222 42.222 12138//boost程序库的转换:int nValue = boost::lexical_cast<int> ("123");long lValue = boost::lexical_cast<long>("123456");long long llValue = boost::lexical_cast<long long>("123456789");double dbValue = boost::lexical_cast<double> ("12.123456");bool bValue = boost::lexical_cast<bool> ("1");std::string Str = boost::lexical_cast<std::string> (123456789);std::cout << typeid(nValue).name() << "\t" << typeid(lValue).name() << "\t" << typeid(llValue).name() << "\t" << typeid(dbValue).name() << "\t" << typeid(bValue).name() << "\t" << typeid(Str).name() << std::endl;std::cout << nValue << "\t" << lValue << "\t" << llValue << "\t" << dbValue << "\t" << bValue << "\t" << Str << std::endl;//输出:int long __int64 double class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >//123 123456 123456789 42.222 123456789//使用bosot转换的时候,如果转化失败,会抛出异常:try {int nValue = boost::lexical_cast<int> ("123");long lValue = boost::lexical_cast<long>("123456");long long llValue = boost::lexical_cast<long long>("123456789");double dbValue = boost::lexical_cast<double> ("12.123456");bool bValue = boost::lexical_cast<bool> ("123");std::string Str = boost::lexical_cast<std::string> (123456789);std::cout << typeid(nValue).name() << "\t" << typeid(lValue).name() << "\t" << typeid(llValue).name() << "\t" << typeid(dbValue).name() << "\t" << typeid(bValue).name() << "\t" << typeid(Str).name() << std::endl;std::cout << nValue << "\t" << lValue << "\t" << llValue << "\t" << dbValue << "\t" << bValue << "\t" << Str << std::endl;}catch (boost::bad_lexical_cast &e) {std::cout << "error" << "\t" << e.what() << std::endl;}//输出:error bad lexical cast: source type value could not be interpreted as target//也可以使用不抛出异常的方式,使用返回的bool来判断是否转换成功:int nNum;boost::conversion::try_lexical_convert(123456, nNum);std::cout << nNum << std::endl;boost::format fmt("%s-%d-%d-%d");std::cout << fmt % "fdjskalf;djska" % 2023 % 05 % 24<<std::endl;//输出:fdjskalf;djska-2023-5-24//也可以使用匿名对象的方式:std::cout << boost::format("%s-%d-%d-%d") % "format" % 2023 % 05 % 31 << std::endl;//输出:format-2023-5-31//实际上,底层进行了二次封装:basic_formatboost::basic_format<char> bfmt("%s-%d-%d-%d");std::cout << bfmt % "bfmit" % 222 % 111 % 000 << std::endl;//输出:bfmit-222-111-0//boost中的轻量化字符串://C++本身在进行字符串的操作的时候,会有一定的成本问题:比如说:const char* str = "This is a string";std::string Str(str); //在这个过程中,存在一次string类的深拷贝过程//使用boost轻量化字符串:也可以使用=赋值的方法(注意这里是字符串的引用,所以不能修改原值boost::string_ref S1(str);boost::string_ref S2(Str);std::cout << S1 << "\t" << S2 << std::endl; //输出:This is a string This is a string//可以指定字符个数:boost::string_ref S3(str, 4);std::cout << S3 << std::endl; //输出:This//字符串的判断:if (S3==S1.substr(0,4)) {std::cout << "==" << std::endl;}//可以在任意位置取出字符:std::cout << S1.front() << std::endl; //Tstd::cout << S1.at(2) << std::endl; //istd::cout << S1.back() << std::endl; //g//含有迭代器:for (auto i = S1.begin(); i != S1.end(); i++) {std::cout << *i;}//This is a stringstd::cout << std::endl;//字符串的比对:这个方法,如同strcmp wcscmp返回0代表比对成功std::cout << S1.compare(S2) << std::endl;//可以取出原始字符串:const char* p = S1.data();std::cout << p << std::endl; //This is a string//查找是否存在字串:auto a = S1.find("is");std::cout << typeid(S1.find("is")).name() << std::endl; //unsigned intstd::cout << a << std::endl; //返回第一次出现的位置//对字符串的判断/等操作,头文件:boost/algorithm/string.hppstd::string Str = "readmi.txt";//判断文件格式,也就是判断字符串尾:if (boost::ends_with(Str, ".txt")) {std::cout << "txt文件" << std::endl;}//判断头部:if (boost::starts_with(Str, "rea")) {std::cout << "rea" << std::endl;}//判断一个字符是否包含另一个字符串:if (boost::contains(Str, "read")) {std::cout << "contains" << std::endl;}//对字符串进行大小写转换:boost::to_upper(Str);std::cout << Str << std::endl; //READMI.TXTboost::to_lower(Str);std::cout << Str << std::endl; //readmi.txt//替换字符:replace_first:替换第一次出现的/replace_last:替换最后一次出现的/replace_all:替换所有std::string Str = "readmeread.txt";//boost::replace_first(Str, "read", "MMMM");//std::cout << Str << std::endl; //MMMMmeread.txt//boost::replace_last(Str, "read", "MMMM");//std::cout << Str << std::endl; //readmeMMMM.txtboost::replace_all(Str, "read", "MMMM");std::cout << Str << std::endl; //MMMMmeMMMM.txt//空格删除://1. 删除所有空格:std::string Str = " abcde ";//boost::trim(Str);std::cout << Str << std::endl; //abcde//2. 删除左边的空格://boost::trim_left(Str); //abcde astd::cout << Str << "a" << std::endl;//3. 删除右边的空格:boost::trim_right(Str);std::cout << Str << "a" << std::endl; //abcdea*///字符串的查找:std::string Str = "readreadreadmereadreadread.txt";std::cout << typeid(boost::find_first(Str, "read")).name() << std::endl; //返回值类型:class boost::iterator_range<class std::_String_iterator<class std::_String_val<struct std::_Simple_types<char> > >auto a = boost::find_first(Str, "read");std::cout << a << std::endl; //read//boost::find_last方法:取出最后出现的//从字符串中取出字符://取出头部6字节:auto head = boost::find_head(Str, 6);std::cout << typeid(boost::find_head(Str, 6)).name() << std::endl; //class boost::iterator_range<class std::_String_iterator<class std::_String_val<struct std::_Simple_types<char> > > >std::cout << head << std::endl; //readre//取出尾部6字节:auto tail = boost::find_tail(Str, 6);std::cout << typeid(boost::find_tail(Str, 6)).name() << std::endl; //class boost::iterator_range<class std::_String_iterator<class std::_String_val<struct std::_Simple_types<char> > > >std::cout << tail << std::endl; //ad.txtreturn 0;
}
如果发现文章中有错误,还请大家指出来,我会非常虚心地学习,我们一起进步!!!
相关文章:
【BOOST程序库】对字符串的处理
基本概念这里不解释了,代码中详细解释了BOOST程序库中对于字符串每一个方法的详细用法: 注意:这里每实践一个方法,都将上面实践过的方法进行了注释,如果全部取消注释,会出现重命名的问题。 #include <…...

(学习笔记-内存管理)虚拟内存
单片机是没有操作系统的,每次写完代码,都需要借助工具把程序烧录进去,这样程序才能跑起来。另外,单片机的CPU是直接操作内存的[物理地址]。 在这种情况下,要想在内存中同时运行两个程序是不可能的。如果第一个程序在 2…...

JVM理论(七)性能监控与调优
概述 性能优化的步骤 性能监控:就是通过以非强行或入侵方式收集或查看应用程序运行状态,包括如下问题 GC频繁CPU过载过高OOM内存泄漏死锁程序响应时间较长性能分析:通常在系统测试环境或者开发环境进行分析 通过查看程序日志以及GC日志,或者运用命令行工…...

复现YOLOv8改进最新MPDIoU:有效和准确的边界盒回归的损失,打败G/E/CIoU,效果明显!!!
MPDIoU: A Loss for Efficient and Accurate Bounding Box Regression 论文简介MPDIoU核心设计思路论文方法实验部分加入YOLOv5代码论文地址:https://arxiv.org/pdf/2307.07662.pdf 论文简介 边界盒回归(Bounding box regression, BBR)广泛应用于目标检测和实例分割,是目标…...

LT6911C 是一款HDMI 1.4到双端口MIPIDSI/CSI或者LVDS加音频的一款高性能芯片
LT6911C 1.描述: LT6911C是一款高性能的HDMI1.4到MIPIDSI/CSI/LVDS芯片,用于VR/智能手机/显示器应用程序。对于MIPIDSI/CSI输出,LT6911C具有可配置的单端口或双端口MIPIDSI/CSI,具有1个高速时钟通道和1个~4个高速数据通道&#…...

vue动态引入静态资源
vue动态引入静态资源 静态资源位置(../../assets/piecture/page404.jpg)或者(/assets/piecture/page404.jpg) 错误引入方式 错误引入方式(一) <template><div><img :src"../../asset…...
perl 强制覆盖拷贝文件
如果你想在Perl中进行文件拷贝时强制覆盖目标文件(如果目标文件已经存在),你可以使用标准模块File::Copy提供的cp函数,它允许你指定是否覆盖目标文件。 以下是一个示例,展示了如何在Perl中进行强制覆盖拷贝文件&#…...

C语言每日一题之整数求二进制1的个数
今天分享一道题目,用三种方法来求解 二进制1的个数 方法1 我们的十进制除10和取余数就可以得到我们每一位的数字,那我们的二进制也可 以 #include<stdio.h> int num_find_1(unsigned int n) {int count 0;while (n){if (1 n % 2){count;}n / 2…...
AcWing 4443.无限区域
原题链接:AcWing 4443.无限区域 题目来源:夏季每日一题2023 给定一个无限大的二维平面,设点 S 为该平面的中心点。 设经过点 S 的垂直方向的直线为 P,如果直线 P 是一个圆的切线,且切点恰好为点 S,那么&a…...

2D坐标系下的点的转换矩阵(平移、缩放、旋转、错切)
文章目录 1. 平移 (Translation)2. 缩放 (Scaling)3. 旋转 (Rotation)4. 错切 (Shearing)5. 镜像 (Reflection) 1. 平移 (Translation)…...
【Rabbitmq】报错:ERROR CachingConnectionFactory Channel shutdown: channel error;
报错内容 ERROR CachingConnectionFactory Channel shutdown: channel error; protocol method: #method<channel.close>(reply-code406, reply-textPRECONDITION_FAILED - unknown delivery tag 1, class-id60, method-id80) 原因 默认是自动ack,然后你代码…...
el-table组件的el-table-column电脑端使用fixed属性固定,移动端不使用固定,怎么实现?
要在电脑端使用 fixed 固定列,而在移动端不使用,可以使用 CSS 媒体查询结合 Vue 的动态绑定来实现。以下是一个示例代码: <template><el-table><el-table-columnprop"name"label"Name":fixed"isDesk…...

RocketMQ 行业分享
5.0的架构发生了重大调整,添加了一层rocketmq-proxy,可以通过grpc的方式接入。 参考 https://juejin.cn/post/7199413150973984827...

物联网场景中的边缘计算解决方案有哪些?
在物联网场景中,边缘计算是一种重要的解决方案,用于在物联网设备和云端之间进行实时数据处理、分析和决策。HiWoo Box作为工业边缘网关设备,具备边缘计算能力,包括单点公式计算、Python脚本编程以及规则引擎,它为物联网…...

【C++ 进阶】学习导论:C/C++ 进阶学习路线、大纲与目标
目录 一、C 学习路线 二、C 课程大纲与学习目标 (1)第一阶段:C 语言基础 (2)第二阶段:C 高级编程 (3)第三阶段:C 核心编程与桌面应用开发 (4…...

【数据结构】实验七:字符串
实验七 字符串实验报告 一、实验目的与要求 1)巩固对串的理解; 2)掌握串的基本操作实现; 3)掌握 BF 和 KMP 算法思想。 二、实验内容 1. 给定一个字符串ababcabcdabcde和一个子串abcd,查找字串是否在主串中出现。…...
排序算法、
描述 由小到大输出成一行,每个数字后面跟一个空格。 输入 三个整数 输出 输入三个整数,按由小到大的顺序输出。 输入样例 1 2 3 1 输出样例 1 1 2 3 输入样例 2 4 5 2 输出样例 2 2 4 5 代码一(如下)࿱…...
rbd快照管理、rbd快照克隆原理与实现、rbd镜像开机自动挂载、ceph文件系统、对象存储、配置对象存储客户端、访问Dashboard
day04 day04快照快照克隆开机自动挂载ceph文件系统使用MDS对象存储配置服务器端配置客户端访问Dashborad 快照 快照可以保存某一时间点时的状态数据快照是映像在特定时间点的只读逻辑副本希望回到以前的一个状态,可以恢复快照使用镜像、快照综合示例 # 1. 在rbd存…...
vue、vuex、vue-router初学导航配合elementui及vscode快捷键
目录 一、vue资源 1.vue知识库汇总 2.vuejs组件 3.Vue.js 组件编码规范 目标 #目录 #基于模块开发...

Elasticsearch:使用 ELSER 释放语义搜索的力量:Elastic Learned Sparse EncoderR
问题陈述 在信息过载的时代,根据上下文含义和用户意图而不是精确的关键字匹配来查找相关搜索结果已成为一项重大挑战。 传统的搜索引擎通常无法理解用户查询的语义上下文,从而导致相关性较低的结果。 解决方案:ELSER Elastic 通过其检索模型…...

业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密
在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...
JVM垃圾回收机制全解析
Java虚拟机(JVM)中的垃圾收集器(Garbage Collector,简称GC)是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象,从而释放内存空间,避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...

C++ Visual Studio 2017厂商给的源码没有.sln文件 易兆微芯片下载工具加开机动画下载。
1.先用Visual Studio 2017打开Yichip YC31xx loader.vcxproj,再用Visual Studio 2022打开。再保侟就有.sln文件了。 易兆微芯片下载工具加开机动画下载 ExtraDownloadFile1Info.\logo.bin|0|0|10D2000|0 MFC应用兼容CMD 在BOOL CYichipYC31xxloaderDlg::OnIni…...

使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台
🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...

处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...

day36-多路IO复用
一、基本概念 (服务器多客户端模型) 定义:单线程或单进程同时监测若干个文件描述符是否可以执行IO操作的能力 作用:应用程序通常需要处理来自多条事件流中的事件,比如我现在用的电脑,需要同时处理键盘鼠标…...

Unity中的transform.up
2025年6月8日,周日下午 在Unity中,transform.up是Transform组件的一个属性,表示游戏对象在世界空间中的“上”方向(Y轴正方向),且会随对象旋转动态变化。以下是关键点解析: 基本定义 transfor…...

ZYNQ学习记录FPGA(一)ZYNQ简介
一、知识准备 1.一些术语,缩写和概念: 1)ZYNQ全称:ZYNQ7000 All Pgrammable SoC 2)SoC:system on chips(片上系统),对比集成电路的SoB(system on board) 3)ARM:处理器…...

Matlab实现任意伪彩色图像可视化显示
Matlab实现任意伪彩色图像可视化显示 1、灰度原始图像2、RGB彩色原始图像 在科研研究中,如何展示好看的实验结果图像非常重要!!! 1、灰度原始图像 灰度图像每个像素点只有一个数值,代表该点的亮度(或…...