string类的常用接口说明

news2025/1/15 23:05:31

STL六大组件:

容器 

算法

配接器

迭代器

仿函数

空间配置器

温馨提示:只讲常用接口,使用方法说明详见代码注释

目录

一、string类对象的常见构造

二、string类对象的容量操作

三、类对象的访问及遍历操作

四、string类对象的修改操作

五、string类非成员函数

六、汇总代码


一、string类对象的常见构造

#include<iostream>
using namespace std;
#include<string>
//typedef basic_string<char16_t> u16string;

std::string s0("Initial string");

//构造空的string类对象,即空字符串(默认构造)
//default (1)	explicit basic_string(const allocator_type& alloc = allocator_type());
std::string s1;

//用C-string来构造string类对象
//copy(2)    basic_string(const basic_string& str);
std::string s2(s0);

//拷贝构造函数
//copy(2)    basic_string(const basic_string& str);
std::string s2(s0);

void Teststring()
{
	string s1;//构造空的string类对象s1
	string s2("hello sunlang");//用C格式字符串构造string类对象s2
	string s3(s2);//拷贝构造s3
}

二、string类对象的容量操作

//返回字符串有效字符长度
//size_type size() const;
int main()
{
	std::string str("Test string");
	std::cout << "The size of str is" << str.size() << "characters.\n";
	return 0;
}
//检测字符串释放为空串,是返回true,否则返回false
//bool empty() const;
int main()
{
	std::string content;
	std::string line;
	std::cout << "Please introduce a text.Enter an empty line to finish:\n";
	do
	{
		getline(std::cin, line);
		content += line + '\n';
	} while (!line.empty());
	std::cout << "The text you introduced was:\n" << content;
	return 0;
}
//清空有效字符
//void clear();
int main()
{
    char c;
    std::string str;
    std::cout << "Please type some lines of text. Enter a dot (.) to finish:\n";
    do {
        c = std::cin.get();
        str += c;
        if (c == '\n')
        {
            std::cout << str;
            str.clear();
        }
    } while (c != '.');
    return 0;
}
//为字符串预留空间**
//void reserve (size_type n = 0);
int main()
{
    std::string str;

    std::ifstream file("test.txt", std::ios::in | std::ios::ate);
    if (file) {
        std::ifstream::streampos filesize = file.tellg();
        str.reserve(filesize);

        file.seekg(0);
        while (!file.eof())
        {
            str += file.get();
        }
        std::cout << str;
    }
    return 0;
}
//将有效字符的个数改成n个,多出的空间用字符C填充
//void resize (size_type n);
//void resize(size_type n, charT c)
int main()
{
	std::string str("I like to code in C");
	std::cout << str << '\n';

	std::string::size_type sz = str.size();

	str.resize(sz + 2, '+');
	std::cout << str << '\n';

	str.resize(14);
	std::cout << str << '\n';
	return 0;
}

三、类对象的访问及遍历操作

//返回pos位置的字符,const string类对象调用
//reference operator[] (size_type pos);
//const_reference operator[] (size_type pos) const;
int main()
{
	std::string str("Test string");
	for (int i = 0; i < str.length(); ++i)
	{
		std::cout << str[i];
	}
	return 0;
}

四、string类对象的修改操作

//在字符串后面追加字符串str
//string(1)
//basic_string& operator+= (const basic_string& str);
//c - string(2)
//basic_string & operator+= (const charT * s);
//character(3)
//basic_string& operator+= (charT c);
int main()
{
	std::string name("John");
	std::string family("Smith");
	name += "K";         // c-string
	name += family;         // string
	name += '\n';           // character

	std::cout << name;
	return 0;
}
//返回C格式字符串
//const charT* c_str() const;
int main()
{
	std::string str("Please split this sentence into tokens");

	char* cstr = new char[str.length() + 1];
	std::strcpy(cstr, str.c_str());

	// cstr now contains a c-string copy of str

	char* p = std::strtok(cstr, " ");
	while (p != 0)
	{
		std::cout << p << '\n';
		p = strtok(NULL, " ");
	}

	delete[] cstr;
	return 0;
}
//从字符串pos位置开始往后找字符C,返回该字符在字符串中的位置
//string(1)
//size_type find(const basic_string& str, size_type pos = 0) const;
//c - string(2)
//size_type find(const charT * s, size_type pos = 0) const;
//buffer(3)
//size_type find(const charT* s, size_type pos, size_type n) const;
//character(4)
//size_type find(charT c, size_type pos = 0) const;
int main()
{
    std::string str("There are two needles in this haystack with needles.");
    std::string str2("needle");

    // different member versions of find in the same order as above:
    std::string::size_type found = str.find(str2);
    if (found != std::string::npos)
        std::cout << "first 'needle' found at: " << found << '\n';

    found = str.find("needles are small", found + 1, 6);
    if (found != std::string::npos)
        std::cout << "second 'needle' found at: " << found << '\n';

    found = str.find("haystack");
    if (found != std::string::npos)
        std::cout << "'haystack' also found at: " << found << '\n';

    found = str.find('.');
    if (found != std::string::npos)
        std::cout << "Period found at: " << found << '\n';

    // let's replace the first needle:
    str.replace(str.find(str2), str2.length(), "preposition");
    std::cout << str << '\n';

    return 0;
}

五、string类非成员函数

//输入运算符重载
//template <class charT, class traits, class Alloc>
//basic_istream<charT, traits>& operator>> (basic_istream<charT, traits>& is,
//	basic_string<charT, traits, Alloc>& str);
int main()
{
	std::string name;

	std::cout << "Please, enter your name: ";
	std::cin >> name;
	std::cout << "Hello, " << name << "!\n";

	return 0;
}
//输出运算符重载
//template <class charT, class traits, class Alloc>
//basic_ostream<charT, traits>& operator<< (basic_ostream<charT, traits>& os,
//	const basic_string<charT, traits, Alloc>& str);
int main()
{
	std::string str = "Hello world!";
	std::cout << str << '\n';
	return 0;
}
//获取一行字符串
//template <class charT, class traits, class Alloc>
//(1)basic_istream<charT, traits>& getline(basic_istream<charT, traits>& is,
//	basic_string<charT, traits, Alloc>& str, charT delim);
//(2)
//template <class charT, class traits, class Alloc>
//basic_istream<charT, traits>& getline(basic_istream<charT, traits>& is,
//	basic_string<charT, traits, Alloc>& str);
int main()
{
	std::string name;

	std::cout << "Please, enter your full name: ";
	std::getline(std::cin, name);
	std::cout << "Hello, " << name << "!\n";

	return 0;
}
//大小比较
int main()
{
	std::string foo = "alpha";
	std::string bar = "beta";

	if (foo == bar) std::cout << "foo and bar are equal\n";
	if (foo != bar) std::cout << "foo and bar are not equal\n";
	if (foo < bar) std::cout << "foo is less than bar\n";
	if (foo > bar) std::cout << "foo is greater than bar\n";
	if (foo <= bar) std::cout << "foo is less than or equal to bar\n";
	if (foo >= bar) std::cout << "foo is greater than or equal to bar\n";

	return 0;
}

六、汇总代码

#include<iostream>
using namespace std;
#include<string>
//测试string容量相关的接口
//size/clear/resize
void Teststring1()
{
	//注意:string类对象支持直接用cin和cout进行输入和输出
	string s("hello,sunlang!!!");//用C-siring来构造string类对象
	cout << s.size() << endl;//返回字符串有效字符长度
	cout << s.length() << endl;//返回字符串有效字符长度
	cout << s.capacity() << endl;//返回空间总大小
	cout << s << endl;
	//将s中的字符串清空,注意清空时只是将size清0,不改变底层空间的大小
	s.clear();
	cout << s.size() << endl;
	cout << s.capacity() << endl;
	//将s中有效字符个数增加到10个,多出位置用‘a'进行补充
	//"aaaaaaaa"
	s.resize(10, 'a');
	cout << s.size() << endl;
	cout << s << endl;
	cout << s.capacity() << endl;
	//将s中有效字符个数增加到15个,多出位置用缺省值'\0'进行补充
	//"aaaaaaaa\0\0\0\0"
	s.resize(15);
	cout << s.size() << endl;
	cout << s.capacity() << endl;
	cout << s << endl;
	//将s中有效字符个数缩小到5个
	s.resize(5);
	cout << s.size() << endl;
	cout << s.capacity() << endl;
	cout << s << endl;
}
void Teststring2()
{
	string s;
	//测试reserve是否会改变string中有效元素个数
	s.reserve(100);
	cout << s.size() << endl;
	cout << s.capacity() << endl;
	//测试reserve参数小于string的底层空间大小时,是否会将空间缩小
	s.reserve(50);
	cout << s.size() << endl;
	cout<<s.capacity()<<endl;
}
//利用reserve提高插入数据的效率,避免增容带来的开销
void TestPushBack()
{
	string s;
	size_t sz = s.capacity();
	cout << "making s grow:\n";
	for (int i = 0; i < 100; ++i)
	{
		s.push_back('c');
		if (sz != s.capacity())
		{
			sz = s.capacity();
			cout << "capacity changed:" << sz << '\n';
		}
	}
}
//构建vector时,如果提前已经知道string中大概要放多少个元素,可以提前将string中空间设置好
void TestPushBackReserve()
{
	string s;
	s.reserve(100);
	size_t sz = s.capacity();
	cout << "making s grow:\n";
	for (int i = 0; i < 100; ++i)
	{
		s.push_back('c');
		if (sz != s.capacity())
		{
			sz = s.capacity();
			cout << "capacity changed:" << sz << '\n';
		}
	}

}
//string的遍历
//begin()+end()   for+[]   范围for
//注意:string遍历时使用最多的还是for+下标或者范围for(C++11后才支持)
//begin()+end()大多数使用在需要使用STL提供的算法操作string时,比如:采用reserve逆置string
void Teststring3()
{
	string s1("hello sunlang");
	const string s2("Hello sunlang");
	cout << s1 << " " << s2 << endl;
	cout << s1[0] << " " << s2[0] << endl;
	
	s1[0] = 'H';
	cout << s1 << endl;
	//s2[0]='h';代码编译失败,因为const类型对象不能修改
}
void Teststring4()
{
	string s("hello sunlang");
	//以下三种方式除了遍历string对象,还可以遍历修改string中的字符
	//第一种使用最多
	//for+operator[]
	for (size_t i = 0; i < s.size(); ++i)
	{
		cout << s[i] << endl;
	}
	//迭代器
	string::iterator it = s.begin();
	while (it != s.end())
	{
		cout << *it << endl;
		++it;
	}
	//string::reserve_iterator rit =s.rbegin();
	//C++11之后,直接使用auto定义迭代器,让编译器推到迭代器的类型
	//auto rit = s.rbegin();
	//while (rit != s.rend())
	//{
	//	cout << *rit << endl;
	//}
	//范围for
	for (auto ch : s)
	{
		cout << ch << endl;
	}
}
//测试string
//1、插入(拼接)方式:push_back append operator+=
//2、正向和反向查找:find()+rfind()
//3、截取子串:substr()
//4、删除:erase
void Teststring5()
{
	string str;
	str.push_back(' ');//在str后插入空格
	str.append("hello");//在str后追加一个字符"hello"
	str += 's';//在str后追加一个字符'b'
	str += "un";//在str后追加一个字符串"it"
	cout << str << endl;
	cout << str.c_str() << endl;//以C语言的方式打印字符串
	//获取file的后缀
	string file("Test.cpp");
	size_t pos = file.rfind('.');
	string suffix(file.substr(pos, file.size() - pos));
	cout << suffix << endl;
	//npos是string里面的一个静态成员变量
	//static const size_t npos=-1;
	//取出ur1中的域名
	string ur1("https://mp.csdn.net/mp_blog/creation/editor/128085730");
	cout << ur1 << endl;
	size_t start = ur1.find("://");
	if (start == string::npos)
	{
		cout << "invalid url" << endl;
		return;
	}
	start += 3;
	size_t finish = url.find('/', start);
	string address = url.substr(start, finish - start);
	cout << address << endl;
	// 删除 url 的协议前缀
	pos = url.find("://");
	url.erase(0, pos + 3);
	cout << url << endl;
}
int main()
{
	Teststring1();
	Teststring2();
	TestPushBack();
	TestPushBackReserve();
	Teststring3();
	Teststring4();
	Teststring5();
	return 0;
}

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

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

相关文章

万古霉素修饰银纳米粒/磁性纳米微球/负载万古霉素PLGA缓释微球/硅包银纳米三角片

小编今天给大家带来的科研知识是万古霉素修饰银纳米粒/磁性纳米微球/负载万古霉素PLGA缓释微球/硅包银纳米三角片&#xff0c;来看&#xff01; 万古霉素修饰磁性纳米微球的制备: 磁性纳米粒子具有纳米粒子一般的特性外还具有超顺磁性,而且通过表面修饰可以连接上不同的生物功…

Windows10安装配置allure

1、allure官方文档&#xff1a; https://docs.qameta.io/allure/#_about 官方文档中&#xff0c;windows部署allure步骤&#xff1a; 奈何提示scoop不是內部命令 2、安装scoop scoop官方文档&#xff1a;https://scoop.sh/ 需要打开power shell&#xff0c;执行提示的两条…

【SQL Server + MySQL二 】SQL: DDL数据定义【定义、修改、删除基本表】,DML【憎删改查】,DCL数据控制语言

极其感动&#xff01;&#xff01;&#xff01;当时学数据库的时候&#xff0c;没白学&#xff01;&#xff01; 时隔很长时间回去看数据库的笔记都能看懂&#xff0c;每次都靠这份笔记巩固真的是语雀分享要花钱&#xff0c;要不一定把笔记给贴出来(;༎ຶД༎ຶ) &#xff0c;除…

SpringCloud搭建微服务之OAuth2实现SSO单点登录

SSO单点登录实现方式有多种&#xff0c;在这里不介绍理论&#xff0c;本文只讨论采用spring-security-oauth2来实现&#xff0c;本文共有三个服务&#xff0c;一个权限认证中心&#xff0c;两个客户端 1. 认证服务搭建 1.1. 引入核心依赖 <dependency><groupId>…

网络服务---OSI七层参考模型及各层工作原理详解

OSI网络模型概念 OSI模型&#xff08;Open System Interconnection/Reference Model&#xff09;是指国际标准化组织(ISO)提出的一个试图使各种计算机在世界范围内互连为网络的标准框架&#xff0c;简称OSI。1981年&#xff0c;为了解决不同体系结构的网络的互联问题&#xff…

在IDEA中配置MySQL数据库连接以及在使用mybatis时设置sql语句的代码提示功能

在IDEA中配置MySQL数据库连接以及在使用mybatis时设置sql语句的代码提示功能 一&#xff1a;在IDEA中配置MySQL数据库连接 第一步&#xff1a;在IDEA右侧区域有database选项&#xff0c;点击进去 第二步&#xff1a;database -> data soucre -> mysql 第三步&#xf…

只看优点,这2款可视化产品你更心水谁?

现代的数据可视化设计一般喜欢追求更加高效的工具&#xff0c;我们在选择可视化工具的时候&#xff0c;一定会被繁多的可视化产品晃得眼花缭乱。今天给大家推荐2款我用过的可视化软件&#xff0c;不谈缺陷&#xff0c;只看优点&#xff0c;看看哪款更和你的心意吧&#xff01; …

Acrel-2000M马达保护与监控系统解决方案具有保护、遥控功能可实现无人或少人值守

安科瑞 李可欣 具体可咨询&#xff1a;Acrel_lkx Acrel-2000M马达保护与监控系统&#xff0c;是根据马达监控系统自动化及无人值守的要求&#xff0c;总结国内外的研究和生产的先进经验&#xff0c;专门研制出的新一代马达监控系统。本系统具有保护、遥测、遥信、遥脉、遥调、…

瑞吉外卖(五) 全局异常处理

全局异常处理如何进行全局异常处理&#xff1f;效果展示**ControllerAdvice**如何进行全局异常处理&#xff1f; 效果展示 ControllerAdvice 本质上就是Component&#xff0c;然后&#xff0c;我们来看一下此类的注释&#xff1a; 这个类是为那些声明了&#xff08;ExceptionH…

Airtest手机APP自动化操作微信

感觉Appium太垃圾了&#xff0c;于是顺手学了下Airtest 安装并解压 官网&#xff0c;有很显眼的下载按钮 下载完zip文件后进行解压 启动自带AirtestIDE.exe 不想登录的可以跳过 因为提前通过数据线连接了手机和电脑了&#xff0c;所以一进去就显示已经连接到手机设备了 当然…

前端css元素yi

996技术站 - 活在未来 | KingSun966技术站&#xff0c;极客带你看世界&#xff01;https://www.996station.com程序员开发指南Descriptionhttps://guide.996station.com css元素溢出 当子元素的尺寸超过父元素的尺寸时&#xff0c;需要设置父元素显示溢出的子元素的方式&#x…

[附源码]SSM计算机毕业设计小锅米线点餐管理系统JAVA

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Redis——》数据类型:bitmap

推荐链接&#xff1a; 总结——》【Java】 总结——》【Mysql】 总结——》【Redis】 总结——》【Spring】 总结——》【SpringBoot】 总结——》【MyBatis、MyBatis-Plus】 Redis——》数据类型&#xff1a;bitmap一、底层结构二、最大长度三、操作示…

IPv6进阶:IPv6 过渡技术之 6to4 自动隧道

实验拓扑 R1-R3-R2之间的网络为IPv4公网&#xff1b;PC1及PC2处于IPv6孤岛。 实验需求 R1及R2为IPv6/IPv4双栈设备&#xff1b;在R1及R2上部署6to4自动隧道使得PC1及PC2能够互相访问。 实验步骤及配置 Internet Router的配置如下 [R3] interface GigabitEthernet0/0/0 [R3…

gan与dcgan训练自己的数据集

gan https://blog.csdn.net/weixin_50113231/article/details/122959899 dcgan 源码地址&#xff1a;https://github.com/carpedm20/DCGAN-tensorflow 安装教程 环境配置 将代码克隆到本地后首先按照官网所需依赖环境进行配置 由于该文章比较早所以python与tensorflow最好按…

做好QA质量管理,4大注意事项和技巧。

1、QA检查单&#xff1a;全过程质量管理体系。 为了做好过程质量管理&#xff0c;QA检查单需要按照检查类型、检查阶段、实践域、检查对象、检查项进行层层划分&#xff0c;构建了全过程质量管理体系。 如QA检查单按照检查阶段划分为&#xff1a;需求分析、系统设计、系统实现、…

5G无线技术基础自学系列 | SU-MIMO原理

素材来源&#xff1a;《5G无线网络规划与优化》 一边学习一边整理内容&#xff0c;并与大家分享&#xff0c;侵权即删&#xff0c;谢谢支持&#xff01; 附上汇总贴&#xff1a;5G无线技术基础自学系列 | 汇总_COCOgsta的博客-CSDN博客 通过多天线技术支持单用户在上下行数据…

SSM考试题库管理系统毕业设计源码069043

SSM考试题库管理系统 摘 要 随着计算机办公自动化程度的不断提高&#xff0c;开发各种数据库管理应用软件用于各种工作中能有效地提高工作效率&#xff0c;节省时间&#xff0c;能使学校的教学工作上一个新的台阶。传统的人工命题形成试卷&#xff0c;往往会出现大量的重复劳动…

java 串口通讯获取检验码

/*** 获取校验码* crc16 X16x15x21* 16进制报文是 02 03 00 00 00 40 CRC16* 传输的str&#xff1a;“020300000040”* 结果&#xff1a;4409* param str* return*/ public static String getCRC(String str) {byte[] bytes NumberUtils.hexStringToBytes(str);int CRC 0x000…

【Spring Boot】Spring Boot 统一功能处理

文章目录Spring拦截器为何需要Spring拦截器&#xff1f;自定义拦截器加入系统配置并配置拦截规则验证登陆拦截器添加统一访问前缀验证统一前缀是否添加成功统一异常处理统一数据返回格式Spring拦截器 为何需要Spring拦截器&#xff1f; 在之前Servlet开发中&#xff0c;对登陆…