代码拉取完成,页面将自动刷新
namespace mystring{
class string{
public:
typedef char* iterator;
iterator begin(){
return _str;
}
iterator end(){
return _str + _size;
}
string(const char* str = "")
:_size(strlen(str))
, _capacity(_size)
{
std::cout << "string(const char* str = \"\") -- 构造" << std::endl;
_str = new char[_capacity + 1];//重新开辟空间
strcpy(_str, str);
}
void swap(string& s){
std::swap(_str, s._str);
std::swap(_size, s._size);
std::swap(_capacity, s._capacity);
}
// 拷贝构造
string(const string& s)
:_str(nullptr)
{
std::cout << "string(const string& s) -- 深拷贝" << std::endl;
string tmp(s._str);
swap(tmp);
}
// 移动构造
string(string&& s)
:_str(nullptr)
, _size(0)
, _capacity(0)
{
std::cout << "string(string&& s) -- 移动构造" << std::endl;
this->swap(s);
}
// 移动赋值
string& operator=(string&& s){
std::cout << "string& operator=(string&& s) -- 移动赋值" << std::endl;
this->swap(s);
return *this;
}
// 赋值重载
string& operator=(const string& s){
string tmp(s);
swap(tmp);
return *this;
}
~string()
{
delete[] _str;
_str = nullptr;
}
char& operator[](size_t pos){
assert(pos < _size);
return _str[pos];
}
void reserve(size_t n){
if (n > _capacity)
{
char* tmp = new char[n + 1];
strcpy(tmp, _str);
delete[] _str;
_str = tmp;
_capacity = n;
}
}
void push_back(char ch){
if (_size >= _capacity)
{
size_t newcapacity = _capacity == 0 ? 4 : _capacity * 2;
reserve(newcapacity);
}
_str[_size] = ch;
++_size;
_str[_size] = '\0';
}
//string operator+=(char ch)
string& operator+=(char ch){
push_back(ch);
return *this;
}
const char* c_str() const{
return _str;
}
private:
char* _str;
size_t _size;
size_t _capacity; // 不包含最后做标识的\0
};
string to_string(int value){
bool flag = true;
if (value < 0){
flag = false;
value = 0 - value;
}
mystring::string str;//创建局部临时对象
while (value > 0){
int x = value % 10;
value /= 10;
str += ('0' + x);
}
if (flag == false){
str += '-';
}
std::reverse(str.begin(), str.end());
return str;
}
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。