0

実際のアプリケーション プロジェクトで C++ プログラムを実行しています。

valgrind を使用してメモリ リーク チェックを行います。

私が得た:

10 ブロックの 160 バイトは、0x4A0846F の損失レコード 1/2 ==14312== で確実に失われます: malloc (vg_replace_malloc.c:236)

しかし、解放するために free() を呼び出しました。

それを修正する方法? メモリリークがあるのはなぜですか?

どんな助けでも大歓迎です。!

コードは次のとおりです。

#include <stdio.h>
#include <stdlib.h>
int * GetSomeIDs() ; 
/*-------- GetSomeIDs-----*/

typedef struct {
       char* alias;   /* '\0'-terminated C string */
       int   specific_id;
} aliasID;

int GetNumberOfAliases(void)
{
    return 10;
}

aliasID *GetNextAlias(void)
{
    aliasID *p = (aliasID *) malloc(sizeof(aliasID)) ;
    p->alias = "test alias";
    p->specific_id = rand();
    return p; 
}

int *GetSomeIDs2(aliasID  ***a, int *aIDsize , int *idSize)
{
    int  *ids  = (int *) malloc(sizeof(int) * 8) ;  
    *idSize = 8 ; 
    int length = GetNumberOfAliases();
    *aIDsize = length ;
    int i  ;
    *a = (aliasID**) malloc(sizeof(aliasID*)*length) ;

    for(i = 0 ; i < length ; ++i)
    {
        (*a)[i] = GetNextAlias();
    }

    return  ids; 
}

void callGetSomeIDs()
{
    aliasID  **aD = NULL;
    int mySize = -1; 
    int myidSize = -1; 
    int *pt = NULL;
    pt = GetSomeIDs2(&aD, &mySize, &myidSize); 
    if (!pt || !aD || mySize <= 0 || myidSize <= 0)
    {
        printf("there is a runt time error of GetSomeIDs \n");
        if (!pt && aD)
        {
            printf("there is a runt time error of GetSomeIDs pt is NULL \n");
            free(aD);
        }
    if (!aD && pt)
        {
            printf("there is a runt time error of GetSomeIDs aD is NULL \n");
            free(pt);
        }
        if (!pt && !aD)
        {
            printf("there is a runt time error of GetSomeIDs aD and pt all NULL \n");
        }

        exit(1);
    }
    // print out 8 int
    printf("the followings are integers  \n");
    int i ;
    for(i = 0 ; i < myidSize ; ++i )
    {
        printf("%d " , pt[i]);
    }
    printf("\n");
    // print out alias and ID 
    printf("the followings are alias and ID  \n");
    for (i = 0 ; i <  mySize   ; ++i )
    {
        printf( "alias is  %s " , (*aD[i]).alias) ;   
            printf( "specific_id is  %d", (*aD[i]).specific_id) ;
        printf("\n") ;
    }

    free(pt);
    free(aD);
  }

  int main()
  {

      callGetSomeIDs();

      return 0; 
   }
4

2 に答える 2

9

構造体の配列を解放しaliasIDますが、配列内の割り当てられたエントリは解放しません。

編集:

最初にaliasIDポインターの配列を割り当ててから、配列内の各エントリに実際の を割り当てますaliasIDaliasID配列を解放する前に、まず配列内のポインターを解放する必要があります。

for (int i = 0; i < length_of_array; i++)
    free(aD[i]);
free(ad);
于 2012-04-24T06:17:16.343 に答える
0

100%確実ではありませんが、コードがGetSomeIDs2の後にifに入った場合、exit(1)を実行するため、無料で実行できません。

また、GetNextAlias()から返されたメモリを解放しません。

于 2012-04-24T06:23:53.487 に答える