String类的默认实现

作者 : admin 本文共1284个字,预计阅读时间需要4分钟 发布时间: 2024-06-17 共1人阅读
#pragma once
#include 
using namespace std;
#include 

namespace yyqx//为了与库里面的string进行区分
{
	//仅仅实现一个简单的string,仅仅考虑资源管理深浅拷贝问题
	class string
	{
	public:

		//构造函数
		string(const char* str)
			:_size(strlen(str))
			,_capacity(_size)
		{
			_str = new char[strlen(str) + 1];//这里的+1,是为了'
#pragma once
#include 
using namespace std;
#include 
namespace yyqx//为了与库里面的string进行区分
{
//仅仅实现一个简单的string,仅仅考虑资源管理深浅拷贝问题
class string
{
public:
//构造函数
string(const char* str)
:_size(strlen(str))
,_capacity(_size)
{
_str = new char[strlen(str) + 1];//这里的+1,是为了'\0'开辟空间
strcpy(_str, str);//拷贝的时候'\0'也拷贝了
}
string()//注意,这里不是给的空,而是给了一个空的字符串//标准库里的就是给了一个""
:_size(0)
,_capacity(0)
{
_str = new char[1];
_str[0] = '\0';
}
//拷贝构造(深拷贝)
//s2(s1)
string(const string& s)
:_size(strlen(s._str))
,_capacity(_size)
{
_str = new char[_capacity + 1];
strcpy(_str, s._str);
}
//赋值,也会有深浅拷贝的问题
string& operator=(const string& s)
{
if (this != &s)//避免自己给自己赋值,会导致值被释放,就会变成随机值
{
char* tmp = new char[s._capacity + 1];
strcpy(tmp, s._str);
delete[] _str;
_str = tmp;
_size = s._size;
_capacity = s._capacity;
}
return *this;
}
//析构函数
~string()
{
if (_str)
{
delete[] _str;
_str = nullptr;//好习惯
_size = 0;
_capacity = 0;
}
}
//目的为了输出字符串
const char* c_str() const
{
return _str;
}//返回c格式的字符串
char& operator[](size_t pos)//这里仅仅可以传入对象,不能传入const对象,如果是const对象,就会报错
{
assert(pos < _size);//注意这里的范围
return _str[pos];
}
const char& operator[](size_t pos) const//这里就可以传入const对象
{
assert(pos < _size);
return _str[pos];
}
//这里的const修饰的是this指针指向的对象const string s;
size_t size() const//写const,普通对象以及const对象都可以调用,如果不加const对象就不可以调用
{
return _size;
}
size_t capacity() const//写const,普通对象以及const对象都可以调用
{
return _capacity;
}
private:
char* _str;
};
}
'开辟空间 strcpy(_str, str);//拷贝的时候'
#pragma once
#include 
using namespace std;
#include 
namespace yyqx//为了与库里面的string进行区分
{
//仅仅实现一个简单的string,仅仅考虑资源管理深浅拷贝问题
class string
{
public:
//构造函数
string(const char* str)
:_size(strlen(str))
,_capacity(_size)
{
_str = new char[strlen(str) + 1];//这里的+1,是为了'\0'开辟空间
strcpy(_str, str);//拷贝的时候'\0'也拷贝了
}
string()//注意,这里不是给的空,而是给了一个空的字符串//标准库里的就是给了一个""
:_size(0)
,_capacity(0)
{
_str = new char[1];
_str[0] = '\0';
}
//拷贝构造(深拷贝)
//s2(s1)
string(const string& s)
:_size(strlen(s._str))
,_capacity(_size)
{
_str = new char[_capacity + 1];
strcpy(_str, s._str);
}
//赋值,也会有深浅拷贝的问题
string& operator=(const string& s)
{
if (this != &s)//避免自己给自己赋值,会导致值被释放,就会变成随机值
{
char* tmp = new char[s._capacity + 1];
strcpy(tmp, s._str);
delete[] _str;
_str = tmp;
_size = s._size;
_capacity = s._capacity;
}
return *this;
}
//析构函数
~string()
{
if (_str)
{
delete[] _str;
_str = nullptr;//好习惯
_size = 0;
_capacity = 0;
}
}
//目的为了输出字符串
const char* c_str() const
{
return _str;
}//返回c格式的字符串
char& operator[](size_t pos)//这里仅仅可以传入对象,不能传入const对象,如果是const对象,就会报错
{
assert(pos < _size);//注意这里的范围
return _str[pos];
}
const char& operator[](size_t pos) const//这里就可以传入const对象
{
assert(pos < _size);
return _str[pos];
}
//这里的const修饰的是this指针指向的对象const string s;
size_t size() const//写const,普通对象以及const对象都可以调用,如果不加const对象就不可以调用
{
return _size;
}
size_t capacity() const//写const,普通对象以及const对象都可以调用
{
return _capacity;
}
private:
char* _str;
};
}
'也拷贝了 } string()//注意,这里不是给的空,而是给了一个空的字符串//标准库里的就是给了一个"" :_size(0) ,_capacity(0) { _str = new char[1]; _str[0] = '
#pragma once
#include 
using namespace std;
#include 
namespace yyqx//为了与库里面的string进行区分
{
//仅仅实现一个简单的string,仅仅考虑资源管理深浅拷贝问题
class string
{
public:
//构造函数
string(const char* str)
:_size(strlen(str))
,_capacity(_size)
{
_str = new char[strlen(str) + 1];//这里的+1,是为了'\0'开辟空间
strcpy(_str, str);//拷贝的时候'\0'也拷贝了
}
string()//注意,这里不是给的空,而是给了一个空的字符串//标准库里的就是给了一个""
:_size(0)
,_capacity(0)
{
_str = new char[1];
_str[0] = '\0';
}
//拷贝构造(深拷贝)
//s2(s1)
string(const string& s)
:_size(strlen(s._str))
,_capacity(_size)
{
_str = new char[_capacity + 1];
strcpy(_str, s._str);
}
//赋值,也会有深浅拷贝的问题
string& operator=(const string& s)
{
if (this != &s)//避免自己给自己赋值,会导致值被释放,就会变成随机值
{
char* tmp = new char[s._capacity + 1];
strcpy(tmp, s._str);
delete[] _str;
_str = tmp;
_size = s._size;
_capacity = s._capacity;
}
return *this;
}
//析构函数
~string()
{
if (_str)
{
delete[] _str;
_str = nullptr;//好习惯
_size = 0;
_capacity = 0;
}
}
//目的为了输出字符串
const char* c_str() const
{
return _str;
}//返回c格式的字符串
char& operator[](size_t pos)//这里仅仅可以传入对象,不能传入const对象,如果是const对象,就会报错
{
assert(pos < _size);//注意这里的范围
return _str[pos];
}
const char& operator[](size_t pos) const//这里就可以传入const对象
{
assert(pos < _size);
return _str[pos];
}
//这里的const修饰的是this指针指向的对象const string s;
size_t size() const//写const,普通对象以及const对象都可以调用,如果不加const对象就不可以调用
{
return _size;
}
size_t capacity() const//写const,普通对象以及const对象都可以调用
{
return _capacity;
}
private:
char* _str;
};
}
'; } //拷贝构造(深拷贝) //s2(s1) string(const string& s) :_size(strlen(s._str)) ,_capacity(_size) { _str = new char[_capacity + 1]; strcpy(_str, s._str); } //赋值,也会有深浅拷贝的问题 string& operator=(const string& s) { if (this != &s)//避免自己给自己赋值,会导致值被释放,就会变成随机值 { char* tmp = new char[s._capacity + 1]; strcpy(tmp, s._str); delete[] _str; _str = tmp; _size = s._size; _capacity = s._capacity; } return *this; } //析构函数 ~string() { if (_str) { delete[] _str; _str = nullptr;//好习惯 _size = 0; _capacity = 0; } } //目的为了输出字符串 const char* c_str() const { return _str; }//返回c格式的字符串 char& operator[](size_t pos)//这里仅仅可以传入对象,不能传入const对象,如果是const对象,就会报错 { assert(pos < _size);//注意这里的范围 return _str[pos]; } const char& operator[](size_t pos) const//这里就可以传入const对象 { assert(pos < _size); return _str[pos]; } //这里的const修饰的是this指针指向的对象const string s; size_t size() const//写const,普通对象以及const对象都可以调用,如果不加const对象就不可以调用 { return _size; } size_t capacity() const//写const,普通对象以及const对象都可以调用 { return _capacity; } private: char* _str; }; }

【C++ • STL】探究string的源码_c++ string 源码-CSDN博客

本站无任何商业行为
个人在线分享 » String类的默认实现
E-->