会社とその所有者に関する情報を保存するために使用される宿題プログラムのメモリ使用量に問題があります。クラスСompanyTemplateはこの情報を表します。
public:
CompanyTemplate (const string & oName,
const string & oAddr,
const string & cName,
const string & cAddr);
別のクラスCCompanyIndexは、ポインターの動的配列を使用して複数のレコードを格納するために使用されます(ベクトルの使用は許可されていません)。CCompanyIndexコンストラクターは次のとおりです。
CCompanyIndex :: CCompanyIndex (void)
{
allocated = 1000;
current_size = 0;
pole = new CompanyTemplate* [allocated];
for (int i=0; i<allocated; i++)
{
pole[i] = NULL;
}
}
CCompanyIndexは、メソッドAdd(レコードの追加)、Del(レコードの削除)、Search(所有者の会社に関する情報の検索)も提供します。Addメソッドに問題があります。基本的なテストはすべて良好ですが、valgrindが言うように、メモリリークがあります。 、Addメソッドで。
bool CCompanyIndex :: Add( const string & oName,
const string & oAddr,
const string & cName,
const string & cAddr )
{
int pos = findPos(oName, oAddr);
if(pos != -1)
{
return false;
}
if ((current_size)>=allocated)
{
CompanyTemplate ** temp;
allocated = allocated*2+1;
temp = new CompanyTemplate* [allocated];
for (int i=0; i<current_size; i++)
{
temp[i]=pole[i];
}
pole = temp;
for (int i=0; i<current_size; i++ )
{
if ((pole[i])->Compare(oName,oAddr)<0)
{
current_size++;
for (int k=current_size-1; k>=i; k--)
{
pole[i] = new Comp pole[k+1]=pole[k];
}anyTemplate(oName, oAddr, cName,cAddr);
return true;
}
}
pole[current_size] = new CompanyTemplate(oName, oAddr, cName,cAddr);
current_size++;
return true;
}
配列要素の再割り当ては期待どおりに機能します。デストラクタでエラーが発生した可能性がありますが、それでも見つかりません。ここにあります:
CCompanyIndex :: ~CCompanyIndex (void)
{
for (int i=0; i<allocated; i++)
{
delete pole[i];
}
delete [] pole;
pole = NULL;
}
ありがとう