【C++初阶】string模拟实现

请添加图片描述

✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿
🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟
🌟🌟 追风赶月莫停留 🌟🌟
🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀
🌟🌟 平芜尽处是春山🌟🌟
🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟
🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅

🍑构造函数

//有参构造
string(char* str)
{
   
	size_t _size = strlen(str);
	_capacity = _size;
	str = new char[_capacity+1];
	strcpy(_str, str);
}
//无参构造
string()
{
   
	_str = new char[1];
	_size = 0;
	_capacity = 0;
	_str[0] = '\0';
}

至于无参构造中,为了防止解引用发生错误,所以特有开了一个空间,并赋值为斜杠0。

上面代码就是普通的构造函数的写法,无参和有参构造,这里我们并不采用初始化列表的方式进行初始化。

但实际我们并不会这么写,会直接写一个全缺省:

string (const char* str = "\0")
{
   
	size_t _size = strlen(str);
	_capacity = _size;
	_str = new char[_capacity+1];
	strcpy(_str, str);
}

上面中初始化时并不能直接赋值给’\0’,str是字符串类型而’\0’是字符,两者类型不一样,所以应赋值"\0"。当然也可以不用赋值,直接空字符串也是,因为常量字符串中自带斜杠0。

🍑析构函数

~string()
{
   
	delete[] _str;
	_str = nullptr;
	_size = _capacity = 0;
}

析构函数就没有什么特别需要注意的了,和常规写法差不多

🍑重载

🍍方括号引用

char& operator[](size_t pos)
{
   
	assert(pos <= _size); 
	return _str[pos];
}

引用在这里的作用是减少拷贝和修改返回值,如果单纯返回该里面的元素,就不会用引用了。

🍍+=操作

string& operator+=(char str)
{
   
	push_back(str);
	return *this;
}

string& operator+=(const char
评论 32
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

悦心无谓

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值