0

我有一个分段错误,想知道我的错误在哪里。

让我解释。

在我的主要声明中,我声明了一个 3D 数组:int*** Matricegroupegeneralisant

然后这个main使用了一个函数recuperationinfoFich(&matricegroupegeneralisant); 这个函数声明为:recuperationinfoFich(int* * * * matricegroupegeneralisant)

此函数recuperationinfoFich使用另一个函数recuperationmatricegroupesgeneralisants(matricegroupegeneralisantA[Ni]); 此函数声明为recuperationmatricegroupesgeneralisants( int*** matricegroupegeneralisant)

我的代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void allocationdynamiquetableautroisdimdentier(int**** Matrice,int nbniveau, int nbligne, int nbcolonne)
{
int i,j;
    *Matrice=(int***) malloc (sizeof(int**)*nbniveau);
    for (i=0; i<nbniveau; i++)
    {
        (*(Matrice))[i]=(int**) malloc (sizeof(int*)*nbligne);  // allocation dynamique de la matrice Matrice
        for (j=0; j<nbligne; j++)
        {
            ((*(Matrice))[i])[j]=(int*) malloc (sizeof(int)*nbcolonne);
        } 
    }
}


void recuperationmatricegroupesgeneralisants(int*** matricegroupegeneralisantA)
{
    (*matricegroupegeneralisantA)[0][1]=1;
}

void recuperationinfoFich(int**** matricegroupegeneralisantA)
{
    allocationdynamiquetableautroisdimdentier(matricegroupegeneralisantA,3, 3, 7);
    recuperationmatricegroupesgeneralisants(matricegroupegeneralisantA[1]);
}



void main(int args, char **argv)
{

    int*** matricegroupegeneralisantA;

    recuperationinfoFich(&matricegroupegeneralisantA);
}

使用 Gdb:

(gdb) r
Starting program: /home/larimsna1/Desktop/a.out 

Breakpoint 1, 0x000000000040061a in main ()
(gdb) n
Single stepping until exit from function main,
which has no line number information.

Program received signal SIGSEGV, Segmentation fault.
0x00000000004005c8 in recuperationmatricegroupesgeneralisants ()
(gdb) 
4

1 回答 1

1

我怀疑这个问题与你的分配功能有关。话虽如此,您提供的代码存在许多功能和风格问题。在一个地方,您未能多次取消引用指针,导致您将整数分配给指针类型。当您根本无法传递参数并使用返回值时,您在大多数事务中不必要地使用指针。

这段代码应该做你想做的事,应该能正常工作,而且更容易阅读:

// allocation, returns pointer to allocated value
int *** allocationdynamique(int nbniveau, int nbligne, int nbcolonne)
{
    int *** Matrice;
    int i, j;
    Matrice = (int ***) malloc (sizeof(*Matrice) * nbniveau);
    for (i = 0; i < nbniveau; ++i)
    {
        Matrice[i] = (int **) malloc (sizeof(**Matrice) * nbligne);
        for (j = 0; j < nbligne; ++j)
        {
            Matrice[i][j] = (int *) malloc (sizeof(***Matrice) * nbcolonne);
        } 
    }
    return Matrice;
}

// computation, takes 2D array, modifies in place
void recuperationmatrice(int** matrice)
{
    matrice[0][1] = 1;
}

// you shouldn't use void main, its not part of the standard
int main(int args, char **argv)
{
    int*** matrice = allocationdynamique(3, 3, 7);
    recuperationmatrice(matrice[1]);

    return 0; 
}

此外,从文体的角度来看,您的变量名称非常长,您应该在运算符周围使用空格。

此代码中的许多错误都是编译器能够检测到并警告您的错误。它们是可以正确编译的有效 C 代码,但在这种情况和大多数其他情况下,它们是错误编写的,无法按预期工作。您应该使用编译器警告进行编译以消除可能的事故:

gcc -Wall -c file.c -o file.o
于 2012-07-30T18:42:17.710 回答