![](/img/trans.png)
[英]std::pair of std::string and custom class fails to copy on std::map::insert(std::make_pair(string, class))
[英]std::make_pair segmentation fault with custom class
我已經改編了一個自定義包裝器,以包含各種類型的數據類型,但是當我創建一個std::make_pair(customClass,customClass)
它崩潰了,我已經使用gdb進行了調試,但是除了聲明此變量和測試它是否已創建並具有值。 我已經深入到std::make_pair()
函數中,它的作用只是構造std :: pair對象,但是我的類是聲明的,而不是指針。 我沒有看到問題...這是代碼
#include <iostream>
#include <string>
#include <vector>
#include <memory>
class any_type
{
public:
virtual ~any_type() {}
virtual void print() = 0;
};
template <class T>
class concrete_type : public any_type
{
public:
concrete_type(const T& value) : value_(value)
{}
virtual void print()
{
std::cout << value_ << '\n';
}
T & get()
{
return dynamic_cast<concrete_type<T>&>(*this).value_;
}
//recently added
concrete_type(const concrete_type<T>& other) : value_(other.value_)
{}
T value_;
private:
};
class WrapperMultiContainner
{
public:
WrapperMultiContainner():mAnyType(0)
{
mAnyType=new concrete_type<int>(-1);
}
//recently added
WrapperMultiContainner(const WrapperMultiContainner & aCopy)
{
//recently added
mAnyType=new concrete_type<decltype(*(aCopy.mAnyType))>(*(aCopy.mAnyType));
//*mAnyType=aCopy.mAnyType;
}
const WrapperMultiContainner & operator=(const WrapperMultiContainner &)
{ return *this;}
template<typename T>
WrapperMultiContainner(T const & aValue= T()):mAnyType(0)
{
mAnyType=new concrete_type<T>(aValue);
}
~WrapperMultiContainner()
{
delete mAnyType;
}
template<typename T>
T & get()
{
return dynamic_cast<concrete_type<T>&>(*mAnyType).value_;
}
template<typename T>
void get(T & aValue,
int & aErrorCode)
{
try{
aValue=dynamic_cast<concrete_type<T>&>(*mAnyType).value_;
aErrorCode=0;
}
catch(...)
{
aErrorCode=-1;
}
//return dynamic_cast<concrete_type<T>&>(*mAnyType).value_;
}
any_type * getAnyType() const
{
return mAnyType;
}
template<typename T>
void set(T const & aGenericValue = T())
{
if(mAnyType)
{
delete mAnyType;
mAnyType=0;
}
mAnyType=new concrete_type<T>(aGenericValue);
}
private:
any_type * mAnyType;
};
int main()
{
std::cout<<"creando el opciones para el builder de comandos"<<std::endl;
//Creacion de las estructuras que tienen las opciones para la creacion de los comandos
std::string aKeyName("idcompdestiny");
WrapperMultiContainner aKey(aKeyName);
aKey.getAnyType()->print();
WrapperMultiContainner aValue(3000);
aValue.getAnyType()->print();
std::pair<WrapperMultiContainner,WrapperMultiContainner> aPair;
aPair=std::make_pair(aKey,aValue);
return 0;
}
創建std :: make_pair崩潰的行。 Thx ind提前!
PD:我添加了復制構造函數,但仍然崩潰
通過部分讀取代碼,您會丟失WrapperMultiContainer
的副本構造WrapperMultiContainer
看,如果您不編寫副本構造函數,將使用默認值。 這將復制指針。 從現在開始,兩個類將具有相同的指針,並且兩個都將在析構函數上將其刪除-您會遇到分段錯誤。
但是同樣,只讀取一半的代碼。
編輯:出於相同的原因,也做一個operator=
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.