[英]Why is my output stream seg faulting and my virtual destructor does not work but when i kill virtual it does
我正在审查测试,并且正在从事我的个人项目,但我正在进行增量开发。 我想在大学学习中表现出色。
它会在我的ostream运算符上出现故障,并且除非没有virtual,否则我的虚拟功能将无法正常工作。
#include"MyString.h"
MyString::MyString( ) //constructor
{
size=0;
capacity=1;
data=new char[capacity];
}
MyString::MyString(char * n) //copy constructor
{
size=strlen(n);
capacity=strlen(n)+1;
data=new char[capacity];
strcpy(data,n);
}
MyString::MyString(const MyString &right) //
{
size=strlen(right.data);
capacity=strlen(right.data)+1;
data=new char [capacity];
strcpy(data,right.data);
}
MyString::~MyString( )
{
delete [] data;
}
MyString MyString::operator = (const MyString& s)
{
if(this!=&s)
{
MyString temp=data;
delete [] data;
size=strlen(s.data);
capacity=size+1;
data= new char [capacity];
strcpy(data,s.data);
}
}
MyString& MyString::append(const MyString& s)
{
if(this!=&s)
{
strcat(data,s.data);
}
}
MyString& MyString::erase()
{
}
MyString MyString::operator + (const MyString&)const
{
}
bool MyString::operator == (const MyString&)
{
}
bool MyString::operator < (const MyString&)
{
}
bool MyString::operator > (const MyString&)
{
}
bool MyString::operator <= (const MyString&)
{
}
bool MyString::operator >= (const MyString&)
{
}
bool MyString::operator != (const MyString&)
{
}
void MyString::operator += (const MyString&)
{
}
char& MyString::operator [ ] (int)
{
}
void MyString::getline(istream&)
{
}
int MyString::length( ) const
{
return strlen(data);
}
ostream& operator<<(ostream& out, MyString& s){
out<<s;
return out;
}
// int MyString::getCapacity(){return capacity;}
实现的operator<<()
是无限递归调用:
ostream& operator<<(ostream& out, MyString& s){
out<<s;
return out;
}
并会导致堆栈溢出。
我想你的意思是:
ostream& operator<<(ostream& out, MyString& s){
out << s.data;
return out;
}
我认为虽然不确定(我认为数据是一个0终止的c字符串),它会更好地工作。
ostream& operator<<(ostream& out, MyString& s) {
out<<s.data;
return out;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.