我是学生,很抱歉有一个愚蠢的问题。尚未完成C lang模块:c
因此,core.c文件中的memcpy();
不能正常工作。也许它只是以我不需要的方式工作。问题是可以帮助您找到以下任务的解决方案:
这个想法是要有一个函数multiply();
,它接受nMatrix [4x4]和nVector [4]指针。它假定要使buffer(tempVector)用于获得相乘的结果,然后将整个结构memcpy
传递给nVector。
但是取而代之的是美丽的乘向量结果,它从内存中产生了垃圾。
同样在超出范围之前,我释放了tempVector数组以防止任何不良的堆内存管理。不幸的是,nVector数组仍然依赖于tempVector复制的内存。
我将不胜感激任何建议! :D
这就是问题代码部分-
核心
#include "core.h"
#include "init.h"
#include <stdlib.h>
#include <stdio.h>
#include <windows.h>
#include <string.h>
#define vecLength 4
typedef struct Vector {
double * vector;
int N;
} Vector;
typedef struct Matrix {
double ** matrix;
int nRow;
int nCol;
} Matrix;
...
...
void multiply(Vector* nVector, Matrix* nMatrix)
{
Vector tempVector;
vectorInit(&tempVector);
for(int i = 0; i < nMatrix->nRow; i++)
for(int j = 0; j < nMatrix->nCol; j++)
tempVector.vector[i]+= nMatrix->matrix[i][j]*nVector->vector[j];
memcpy(nVector,&tempVector,sizeof(Vector));
vectorFree(&tempVector);
}
main.c
int main(){
...
...
Vector* v_Test;
Matrix* m_Test;
//Test structures memory allocation
v_Test = (Vector*) malloc(sizeof(Vector));
m_Test = (Matrix*) malloc(sizeof(Matrix));
//Initialization of vector in structure
vectorInit(v_Test);
for(int i = 0; i < v_Test->N; i++)
v_Test->vector[i]=i+1;
//Print vector
vectorPrint(v_Test);
getch();
//Initialization of matrix in structure
matrixInit(m_Test);
for(int i=0; i<m_Test->nCol; i++)
for(int j=0; j<m_Test->nCol;j++)
m_Test->matrix[i][j]=m_Test->nRow*i+j;
//Print matrix
matrixPrint(m_Test);
getch();
multiply(v_Test,m_Test);
vectorPrint(v_Test);
getch();
vectorFree(v_Test);
getch();
matrixFree(m_Test);
getch();
}
...
...
}
最佳答案
已经通过尝试上载之前的最后一个想法找到了解决方案。因此,当您调用memcpy
时,它仅复制向量的数组指针,该向量将在下一条指令vectorFree();
中释放。因此,为防止这种情况,我们只是将实际数组从tempVector复制到nVector结构!*
代码中的解决方案:
memcpy(nVector-> vector,tempVector.vector,vecLength * sizeof(double));
我仍然上传它,因为我花了45分钟来写这个问题。我希望它将对以后的所有人有所帮助:)
保持冷静,并度过美好的一天:D