✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿
🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟
🌟🌟 追风赶月莫停留 🌟🌟
🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀🍀
🌟🌟 平芜尽处是春山🌟🌟
🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟🌟
🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿
✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨
✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅
🍑构造函数
//有参构造
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