嗨,我正在用C编写一个程序,但是我在运行程序时遇到了分段错误。
我使用gcc进行编译,在编译时没有给出警告或错误。
我试着用gdb追踪segfault的起源,它指引我到一条线,在这条线中,我将数据值分配给我的二维数组:
数组[行][列]=数据值;
当我运行我的程序存储3个数据值,然后seg故障。它应该将数据存储在424行117列中,但在仅存储3个数据值之后,它会始终隔离故障。
我的代码如下(省略了一些细节):

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

void allmem(float** fpdata,...);            // allocate memory header
void stored(float** fpdata,...);            // store data header
void countnumber(int* num1, int*num2,...);  // count header

int main()   // main() function
{
int numberofrows = 424; // number of rows
float** fpdata;         // two dimensional array fpdata of floats

allmem(fpdata,...);     // call allocate memory function
stored(fpdata,...);     // call function to store data
...
return 0;
} // main ()

// --------------stored() function---------------
void stored(float** fpreal,...) {

FILE *fp;                  // file pointer
float datavalue;           // variable to hold data values read
int row;
int column;

fp = fopen("c:/file.txt","r");

for(column = 0; column < 117; column++) {
  for(row = 0; row < 424; row++) {
    fscanf(fp, "%f,", &datavalue);
    fpdata[row][column] = datavalue;
  } // for
} // for
fclose(fp);
} // stored()

// ----------allmem() function----------------
// function to allocate memory for two dimensional arrays
// I have hard coded the values of the array sizes in, but
// in my actual program they are calculated at run time based
// on the size of some input files and this is done in the
// countnumber() function

void allmem(float** fpdata,...) {
int i = 0;
fpdata = (float**) malloc((424)*sizeof(float*));
fpdata2 = (float**) malloc((424)*sizeof(float*));
...
for (i = 0; i<424; i++) {
  fpdata[i] = (float*) malloc((117)*sizeof(float));
  fpdata2[i] = (float*) malloc((117)*sizeof(float));
} // for

} // allmem()

最佳答案

fpdata是按值而不是指针或引用传递的。这意味着当函数从allmem返回时,fpdata仍然指向它以前做过的相同事情,并且分配的内存丢失。
您需要致电allmem(&fpdata,...);
并使用void allmem(float*** fpdata,...)的函数签名
然后,在allmem中,设置*fpdata = (float**)...
当然,(*fpdata)[i] = (float*) malloc...在“for”循环中。
编辑:
我希望你对fpdata2也这么做。但您不必更改stored()中的任何内容(尽管看起来您传入了fpreal,但将值赋给了fpdata,这可能只是一个简化的代码错误?)。传递给stored的指针应该是有效的。您并不是试图更改stored中的指针,而是它指向的内存中的值。

07-24 14:05