私は文字列クラスの非常に単純な実装を C++ で書き始めました。コードは次のとおりです。
class String
{
public:
String()
{
this->_length = 0;
this->_size = 0;
this->_string = NULL;
}
String(const char* str)
{
this->_length = strlen(str);
this->_size = this->_length + 1;
this->_string = new char[this->_size];
strcpy_s(this->_string, this->_size, str);
}
~String()
{
if (this->_string != NULL)
{
delete[] this->_string;
this->_string = NULL;
}
}
String& operator+(const char* str)
{
String* temp = new String();
temp->_length = strlen(str) + strlen(this->_string);
temp->_size = temp->_length + 1;
temp->_string = new char[temp->_size];
strcpy_s(temp->_string, temp->_size, this->_string);
strcat_s(temp->_string, temp->_size, str);
return (String&)*temp;
}
int Length()
{
return this->_length;
}
private:
int _size;
int _length;
char* _string;
};
私の operator+ の実装は完全に間違っていることがわかります。実際、メモリ リークがあります。char* を this->_string と単純に連結して *this を返すことができるため、operator+= の記述は非常に簡単です。operator+ の実装について助けが必要です。
注:これは宿題なので、コピーアンドペーストで解決したくありませんが、誰かが私を正しい方向に向けることができれば素晴らしいでしょう...
ありがとう
編集:コピーコンストラクターを追加しました:
String(const String& str)
{
this->_length = str._length;
this->_size = str._size;
this->_string = new char[this->_size];
strcpy_s(this->_string, this->_size, str._string);
}
operator= と operator+=:
String& operator=(const String& str)
{
if (this != &str)
{
this->_length = str._length;
this->_size = str._size;
this->_string = new char[this->_size];
strcpy_s(this->_string, this->_size, str._string);
}
return *this;
}
String& operator+=(const String& str)
{
this->_length = this->_length + str._length;
this->_size = this->_length + 1;
char* buffer = new char[this->_size];
strcpy_s(buffer, this->_size, this->_string);
strcat_s(buffer, this->_size, str._string);
delete[] this->_string;
this->_string = buffer;
return *this;
}
しかし、次のように while(true) ループを実行すると、まだ何か問題があります。
while (true)
{
String a = String("string a");
String b = a;
b = "string b";
b += " string c";
}
プロセスによって使用されるメモリは継続的に増加します