【C++】string 之 assign、at、append函数的学习

news2025/1/12 7:48:04

前言

在学习string类的过程中,我发现了assign这个函数,感觉很有用,就来记录一下

assign函数原型:

void assign(size_type n, const T& x = T());

void assign(const_iterator first, const_iterator last);

assign函数有两种使用方式:

第一种:容器名.assign (a, b);

容器名.assign (a, b);

将vector中的内容清空,并给予a个b元素

下面给出一个例子:

#include<iostream>
#include<vector>
using namespace std;

int main()
{
	vector<int>v1{ 1,2,3 };
	//创建一个容器v1 元素类型是int 有三个元素

	v1.assign(2, 5);
	
	for (int val : v1)
	{
		cout << val << endl;
	}

	cout << "--------------------" << endl;

	v1.assign(4, 5);

	for (int val : v1)
	{
		cout << val << endl;
	}

	cout << "--------------------" << endl;

	int a = 2;
	int b = 3;
	int n = a * b;
	int x;
	v1.assign(n, x);
	for (int val : v1)
	{
		cout << val << endl;
	}

	cout << "--------------------" << endl;

	return 0;
}

通过上面这个例子,我们可以发现,首先,在传入新的元素之前,assign函数会先清空vector中的内容,之后,再传入新的数据,并且,无论是传入一个变量,还是传入未初始化的变量,都可以实现assign的功能

注意:第一个元素,即要传入的元素个数不能是未初始化的变量,不然程序会报错

第二种:容器名2.assign(容器名1.begin(),容器名1.end());

容器名2.assign(容器名1.begin(),容器名1.end());

提示:
这种使用方法的含义就是:
将容器1中的begin()和end()之间的元素放到容器2中,包含起始位置和终止位置。同样的,也是先清空容器2中的内容

下面给出一个例子:

#include<iostream>
#include<vector>

using namespace std;

int main()
{
	vector<int>v1{ 1,2,3 };
	vector<int>v2{ 1,2 };

	v2.assign(v1.begin(), v1.end());

	for (int val : v2)
	{
		cout << val << endl;
	}

	cout << "--------------" << endl;

	v2.assign(v1.begin() + 1, v1.end() - 1);

	for (int val : v2)
	{
		cout << val << endl;
	}

	cout << "--------------" << endl;

	return 0;
}

通过上面这些例子,相信我们就可以基本明白assign是如何使用的了

at函数

函数源码

vector<_Tp, _Allocator>::at(size_type __n)
{
	if (__n >= size())
		this->__throw_out_of_range();
	return this->__begin_[__n];
}

了解即可,不用深究

at函数的使用

arr[3]与arr.at(3)的效果是一样的,只是使用at函数,不会发生越界访问的情况,更加安全

举个例子:

#include<iostream>
#include<vector>
#include<algorithm>

using namespace std;

int main()
{
	vector<int>arr{ 1,2,3,4,5 };

	for (int i = 0; i < arr.size(); i++)
	{
		cout << arr.at(i) << endl;
	}

	//cout << arr.at(5) << endl;
	return 0;
}

运行结果:
在这里插入图片描述
相信通过上面的学习,我们已经明白了如何使用at函数

append函数

接下来,我们来学习append函数

用法1:完全复制

格式:

append函数的使用格式:

字符串1.append(字符串2);

例子:

下面,举一个例子,方便大家理解:

#include<iostream>

using namespace std;

int main()
{
	string a = "qaz";
	string b = "wsx";
	string c = "edc";
	cout << a << endl;

	a.append(b);

	cout << a << endl;

	a.append(b + c);

	cout << a;

	return 0;
}

运行结果:
在这里插入图片描述
通过上面这个例子,我们可以知道虽然append函数一次只能复制一个字符串,但这个字符串是可以先运算的,比如:b+c

用法2:部分复制(后面的字符)

append除了复制全部内容以外,还可以选取部分进行复制

格式:

使用格式:

字符串1.append(字符串2,起始位置index,复制元素个数n);

作用:
将字符串2中第index个位置开始(包含起始位置的元素),共n个元素,拷贝到字符串1的末尾

例子:

下面给出一段代码,方便大家理解:

#include<iostream>

using std::string;
using std::cout;
using std::endl;

int main()
{
	string a = "hello";
	string b = "world";
	cout << a << endl;

	a.append(b, 2, 3);

	cout << a << endl;

	return 0;
}

运行结果:
在这里插入图片描述
特别的:
当只传入起始位置index,而不传入复制元素个数n的时候,编译器默认拷贝到字符串末尾

用法3:部分复制(前面的字符)

格式:

字符串1.append(C语言风格的字符串2,复制元素的个数n);

将字符串2中从开始位置算起,共复制n个元素放到字符串1的末尾

例子:

#include<iostream>

using namespace std;

int main()
{
	string a = "hello";
	const char* b = "world";

	a.append(b, 3);

	cout << a << endl;

	return 0;
}

运行结果:
在这里插入图片描述

注意:

直接传入字符串的时候,编译器默认它是C语言风格的字符串

例子如下:

#include<iostream>

using namespace std;

int main()
{
	string a = "hello";
	a.append("world", 5);

	cout << a << endl;

	return 0;
}

在这里插入图片描述

用法4:复制相同字符

格式:

字符串1.append(复制字符的个数n,复制的字符ch);

作用:
将n个ch复制到字符串1的后面

例子:

#include<iostream>

using namespace std;

int main()
{
	string a = "hello";

	char c = '!';

	a.append(3, c);

	cout << a << endl;

	int n = 4;

	a.append(n, 'h');

	cout << a << endl;

	return 0;
}

运行结果:
在这里插入图片描述

结语

对于assign、at和append函数的学习和介绍到这里就结束了,希望这篇文章对你有帮助,我们下次见~

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

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

相关文章

格林公式推导

∫ D ∫ ( ∂ Q ∂ x − ∂ P ∂ y ) d x d y ∮ P d x Q d y \int _D \int (\frac{\partial Q}{\partial x} - \frac{\partial P}{\partial y})dx dy \oint P dx Qdy ∫D​∫(∂x∂Q​−∂y∂P​)dxdy∮PdxQdy 证明&#xff1a; 假设 ∫ Q ( x , y ) d y 的原函数是 q …

linux万字图文学习进程信号

1. 信号概念 信号是进程之间事件异步通知的一种方式&#xff0c;属于软中断。 1.1 linux中我们常用Ctrlc来杀死一个前台进程 1. Ctrl-C 产生的信号只能发给前台进程。一个命令后面加个&可以放到后台运行,这样Shell不必等待进程结束就可以接受新的命令,启动新的进程。2. S…

Git的ssh方式如何配置,如何通过ssh方式拉取和提交代码

git的ssh配置 HTTPS和SSH的区别设置SSH方式配置单个仓库配置账户公钥 大家通过git拉取代码的时候&#xff0c;一般都是通过http的方式&#xff0c;简单方便。但是细心的童鞋肯定也注意到Git也是支持ssh方式的。可能很多人也试过使用这个方式&#xff0c;但是好像没有那么简单。…

企业架构LNMP学习笔记57

MongoDB的安全设置&#xff1a; 安全&#xff1a; MongoDB的安全事件&#xff1a; 2017年年初&#xff1a; 利用SMB漏洞可以获得系统最高权限。wannacry勒索病毒。当年确实遇到过这个事情。 比特币的概念&#xff1a;开源软件 P2P网络 P2P形式的数字货币。交易记录公开透明。…

Mysql--Java的JDBC编程

Java的数据库编程&#xff1a;JDBC JDBC&#xff0c;即Java Database Connectivity&#xff0c;java数据库连接。是一种用于执行SQL语句的Java API&#xff0c;它是 Java中的数据库连接规范。 下载驱动包作为项目的依赖&#xff0c;数据库驱动包的版本要和数据库服务器的版本…

前端中的跨域请求及其解决方案

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 跨域&#xff08;Cross-Origin&#xff09;⭐CORS&#xff08;跨域资源共享&#xff09;⭐JSONP&#xff08;JSON with Padding&#xff09;⭐代理服务器⭐ WebSocket⭐服务器设置响应头⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a…

Spring + vue 项目部署(全网最详细教程_含内网穿透部署)

本项目以Springboot 2.7.11和vue2做参考示例 第一步 展示前后端代码的成品 前端Vue 后端Java 项目写完后&#xff0c;差不多就是这个样子&#xff0c;仅供参考&#xff01; 第二步 开始打包前后端项目 前端打包的方式有以下几种&#xff1a; 方法1: #直接打包&#xff0…

【数据结构】【C++】红黑树RBTree的模拟实现(平衡搜索二叉树)

【数据结构】&&【C】红黑树的模拟实现(平衡搜索二叉树&#xff09; 一.红黑树的性质二.红黑树的模拟实现1.结点的定义2.搜索树的插入3.变色向上处理4.旋转变色 三.红黑树与AVL树的差别四.完整代码 一.红黑树的性质 1.什么是红黑树&#xff1f; 红黑树是一种搜索二叉树…

页面上下左右滑动事件

1.下载插件 npm install vue-touchnext -S 2.main.js加入以下代码 import VueTouch from vue-touch Vue.use(VueTouch, { name: v-touch }) VueTouch.config.swipe { threshold: 50 //设置左右滑动的距离 } 3.完整代码 <template><div><v-touch swipe…

Java 基础——运行第一个Java程序

【学习笔记】Java 基础——运行第一个Java程序 关键词&#xff1a;Java、Spring Boot、Idea、数据库、一对一、培训、教学本文主要内容是在IDEA中运行第一个Java程序&#xff1a;Hello World计划30分钟完成&#xff0c;请同学尽量准备工具有学习需要请联系&#xff1a;xujian_…

css多个物体椭圆旋转

实现效果 html代码 <div class"background-img"><div class"area"><div class"ball ball1"></div><div class"ball ball2"></div><div class"ball ball3"></div><div …

道路空间功率谱密度与时间功率谱密度(笔记)

1.先上代码其中之一 clc clear close all %% SimTime200; dt0.01;%仿真步长 time0:dt:SimTime; sim_step length(time); Ntlength(time); % 采样点&#xff08;可能要修改&#xff09; u10; % m/s df1/(Nt*dt); % 采样频率间隔 f0:df:1/(2*dt); % 采用频率一…

数据脱敏的风险量化评估介绍

1、背景介绍 当前社会信息化高速发展&#xff0c;网络信息共享加速互通&#xff0c;数据呈现出规模大、流传快、类型多以及价值密度低的特点。人们可以很容易地对各类数据实现采集、发布、存储与分析&#xff0c;然而一旦带有敏感信息的数据被攻击者获取将会造成个人隐私的严重…

NTIRE2023-RTSR-Track2 冠军方案详解

编辑 | Happy 首发 | AIWalker 链接 | https://mp.weixin.qq.com/s/JQ5g9yn_OdjR8hi_tWc4jA arXiv:2305.02126 , cvpr2023 , code , video 本文了一个实时&轻量图像超分方案Bicubic&#xff0c;它通过下采样模块降低图像分辨率以减少计算量&#xff0c;在网络尾部采用…

R语言绘制染色体变异位置分布图,RIdeogram包

变异位点染色体分布图 今天分享的内容是通过RIdeogram包绘制染色体位点分布图&#xff0c;并介绍一种展示差异位点的方法。 在遗传学研究中&#xff0c;通过测序等方式获得了基因组上某些位置的基因型信息。 如下表&#xff0c;第一列是变异位点的ID&#xff0c;第二列是染色体…

Python 字典的定义

视频版教程 Python3零基础7天入门实战视频教程 字典dict 字典也是Python提供的一种常用的数据结构&#xff0c;它用于存放具有映射关系的数据。 字典的定义 比如有成绩表数据——语文:68&#xff0c;数学:98&#xff0c;英语: 76&#xff0c;这组数据看上去像两个列表&…

每天几道Java面试题:集合(第四天)

目录 第四幕 、第一场&#xff09;大厦楼下门口第二场&#xff09;大门口 友情提醒 背面试题很枯燥&#xff0c;加入一些戏剧场景故事人物来加深记忆。PS:点击文章目录可直接跳转到文章指定位置。 第四幕 、 第一场&#xff09;大厦楼下门口 【面试者老王&#xff0c;门卫甲…

浅谈C++|STL之stack+queue+priority_queue篇

一.stack基本概念 栈&#xff08;Stack&#xff09;是一种常见的线性数据结构&#xff0c;遵循后进先出&#xff08;Last-In-First-Out&#xff0c;LIFO&#xff09;的原则。类似于我们在现实生活中堆叠书本或盘子的方式&#xff0c;最后放入的元素最先被取出。 在栈中&#…

【基于多输出方向的同步异步日志系统】

本项目涉及的到所有源码见以下链接&#xff1a; https://gitee.com/ace-zhe/wz_log 一、项目简介 1.日志的概念&#xff08;白话版&#xff09; 日志类似于日记&#xff0c;通常是指对完成某件事情的过程中状态等的记录&#xff0c;而计算机中的日志是指日志数据&#xff0c…

Python实现的mqtt客户端工具分享,小巧且超轻量级(python+tkinter+paho.mqtt)

mqtt协议调试时需要个客户端工具&#xff0c;但网上找的体积包都很大&#xff0c;都不够小巧和便携。于是趁周末时间用python搞出来了个客户端工具&#xff0c;使用pythontinkerpaho.mqtt实现。源码量很少但功能不弱&#xff0c;相当的轻量级。分享给有需要的小伙伴&#xff0c…