C++ 中内存的动态分配
Dynamic Allocation of Memory in C++
我试图找出 C++ 中的动态分配,但我遇到了一个问题。
#include <stdio.h>
#include <malloc.h>
float *alocareV(int n)
{
float *v;
v = (float *)malloc(n*sizeof(float));
return v;
}
float **alocareM(int m, int p)
{
float **a;
int i;
a = (float **)malloc(m*sizeof(float));
for (i = 0; i < m; i++)
*(a + i) = (float *)malloc(p*sizeof(float));
return a;
}
void dezalocareM(float **a ,int p)
{
int i;
for (i = 0; i < p; i++)
free (*(a + i));
}
void citireV(float *v, int n)
{
int i;
for (i = 0; i < n; i++)
{
printf("v[%d]= ", i);
scanf_s("%f", *(v + i));
}
}
void citireM(float **a, int m, int p)
{
int i, j;
for (i = 0; i < m;i++)
for (j = 0; j < p; j++)
{
printf("a[%d][%d]= ", i, j);
scanf_s("%f", *( *(a + i) + j ) );
}
}
void main()
{
float *v=0, **a=0;
int n, m, p;
int i, j;
printf("n este egal cu ");
scanf_s("%d", &n);
printf("m este egal cu ");
scanf_s("%d", &m);
printf("p este egal cu ");
scanf_s("%d", &p);
alocareV(n);
alocareM(m, p);
citireV(v, n);
citireM(a, m, p);
free(v);
dezalocareM(a, p);
}
首先,我必须在 main 中初始化 *v=0 和 **a=0,因为我收到一个错误提示 "uninitialized local variable used"。如果我不使用子程序,则不会出现该错误。
其次,在输入 3 个变量 (n、m、p) 后,我得到一个停止工作的盒子,问题细节是:
Problem signature:
Problem Event Name: APPCRASH
Application Name: AlocareDinamica.exe
Application Version: 0.0.0.0
Application Timestamp: 54f1d7f9
Fault Module Name: AlocareDinamica.exe
Fault Module Version: 0.0.0.0
Fault Module Timestamp: 54f1d7f9
Exception Code: c0000005
Exception Offset: 00014059
OS Version: 6.3.9600.2.0.0.768.100
Locale ID: 1033
Additional Information 1: 5861
Additional Information 2: 5861822e1919d7c014bbb064c64908b2
Additional Information 3: a10f
Additional Information 4: a10ff7d2bb2516fdc753f9c34fc3b069
有人可以帮忙吗?谢谢
正确的代码应该是:
#include <stdio.h>
#include <malloc.h>
float *alocareV(int n)
{
float *v;
v = (float *)malloc(n*sizeof(float));
return v;
}
float **alocareM(int m, int p)
{
float **a;
int i;
a = (float **)malloc(m*sizeof(float *));
for (i = 0; i < m; i++)
*(a + i) = (float *)malloc(p*sizeof(float));
return a;
}
void dezalocareM(float **a ,int p)
{
int i;
for (i = 0; i < p; i++)
free (*(a + i));
}
void citireV(float *v, int n)
{
int i;
for (i = 0; i < n; i++)
{
printf("v[%d]= ", i);
scanf_s("%f", (v + i));
}
}
void citireM(float **a, int m, int p)
{
int i, j;
for (i = 0; i < m;i++)
for (j = 0; j < p; j++)
{
printf("a[%d][%d]= ", i, j);
scanf_s("%f", ( *(a + i) + j ) );
}
}
void main()
{
float *v=0, **a=0;
int n, m, p;
int i, j;
printf("n este egal cu ");
scanf_s("%d", &n);
printf("m este egal cu ");
scanf_s("%d", &m);
printf("p este egal cu ");
scanf_s("%d", &p);
v = alocareV(n);
a = alocareM(m, p);
citireV(v, n);
citireM(a, m, p);
free(v);
dezalocareM(a, p);
}
改变
alocareV(n);
alocareM(m, p);
在主函数中:
v = alocareV(n);
a = alocareM(m, p);
还修改了 scanf_s 函数参数。希望对您有所帮助。
首先请注意,您的问题与 C++ 关系不大。据我所知,它完全是C。在 C++ 中,在处理低级内存业务的 罕见 情况下,您将使用 new
而不是 malloc
,而 类 像std::string
或 std::vector
更高级别。
不过,让我们看看这里出了什么问题。
最明显的问题是alocareV
和citireV
之间没有联系,alocareM
/citireM
也一样。您的分配函数的结果 被丢弃 。您必须使用结果:
v = alocareV(n);
a = alocareM(m, p);
alocareM
也有错误。当你为双指针分配内存时,你应该使用sizeof(float*)
,而不是sizeof(float)
。
下一个错误在 citireV
。 scanf_s
要求您传递指向要写入的对象的指针。但是,*(v + i)
会生成 float
,而不是 float*
,因为您取消引用了指针。正确的调用是:
scanf_s("%f", (v + i));
citireM
有完全相同的错误。正确的调用应该是:
scanf_s("%f", ( *(a + i) + j ) );
最后,main
必须returnint
。 void main
在 C 或 C++ 中是不合法的。
这应该可以解决问题。
我试图找出 C++ 中的动态分配,但我遇到了一个问题。
#include <stdio.h>
#include <malloc.h>
float *alocareV(int n)
{
float *v;
v = (float *)malloc(n*sizeof(float));
return v;
}
float **alocareM(int m, int p)
{
float **a;
int i;
a = (float **)malloc(m*sizeof(float));
for (i = 0; i < m; i++)
*(a + i) = (float *)malloc(p*sizeof(float));
return a;
}
void dezalocareM(float **a ,int p)
{
int i;
for (i = 0; i < p; i++)
free (*(a + i));
}
void citireV(float *v, int n)
{
int i;
for (i = 0; i < n; i++)
{
printf("v[%d]= ", i);
scanf_s("%f", *(v + i));
}
}
void citireM(float **a, int m, int p)
{
int i, j;
for (i = 0; i < m;i++)
for (j = 0; j < p; j++)
{
printf("a[%d][%d]= ", i, j);
scanf_s("%f", *( *(a + i) + j ) );
}
}
void main()
{
float *v=0, **a=0;
int n, m, p;
int i, j;
printf("n este egal cu ");
scanf_s("%d", &n);
printf("m este egal cu ");
scanf_s("%d", &m);
printf("p este egal cu ");
scanf_s("%d", &p);
alocareV(n);
alocareM(m, p);
citireV(v, n);
citireM(a, m, p);
free(v);
dezalocareM(a, p);
}
首先,我必须在 main 中初始化 *v=0 和 **a=0,因为我收到一个错误提示 "uninitialized local variable used"。如果我不使用子程序,则不会出现该错误。 其次,在输入 3 个变量 (n、m、p) 后,我得到一个停止工作的盒子,问题细节是:
Problem signature:
Problem Event Name: APPCRASH
Application Name: AlocareDinamica.exe
Application Version: 0.0.0.0
Application Timestamp: 54f1d7f9
Fault Module Name: AlocareDinamica.exe
Fault Module Version: 0.0.0.0
Fault Module Timestamp: 54f1d7f9
Exception Code: c0000005
Exception Offset: 00014059
OS Version: 6.3.9600.2.0.0.768.100
Locale ID: 1033
Additional Information 1: 5861
Additional Information 2: 5861822e1919d7c014bbb064c64908b2
Additional Information 3: a10f
Additional Information 4: a10ff7d2bb2516fdc753f9c34fc3b069
有人可以帮忙吗?谢谢
正确的代码应该是:
#include <stdio.h>
#include <malloc.h>
float *alocareV(int n)
{
float *v;
v = (float *)malloc(n*sizeof(float));
return v;
}
float **alocareM(int m, int p)
{
float **a;
int i;
a = (float **)malloc(m*sizeof(float *));
for (i = 0; i < m; i++)
*(a + i) = (float *)malloc(p*sizeof(float));
return a;
}
void dezalocareM(float **a ,int p)
{
int i;
for (i = 0; i < p; i++)
free (*(a + i));
}
void citireV(float *v, int n)
{
int i;
for (i = 0; i < n; i++)
{
printf("v[%d]= ", i);
scanf_s("%f", (v + i));
}
}
void citireM(float **a, int m, int p)
{
int i, j;
for (i = 0; i < m;i++)
for (j = 0; j < p; j++)
{
printf("a[%d][%d]= ", i, j);
scanf_s("%f", ( *(a + i) + j ) );
}
}
void main()
{
float *v=0, **a=0;
int n, m, p;
int i, j;
printf("n este egal cu ");
scanf_s("%d", &n);
printf("m este egal cu ");
scanf_s("%d", &m);
printf("p este egal cu ");
scanf_s("%d", &p);
v = alocareV(n);
a = alocareM(m, p);
citireV(v, n);
citireM(a, m, p);
free(v);
dezalocareM(a, p);
}
改变
alocareV(n);
alocareM(m, p);
在主函数中:
v = alocareV(n);
a = alocareM(m, p);
还修改了 scanf_s 函数参数。希望对您有所帮助。
首先请注意,您的问题与 C++ 关系不大。据我所知,它完全是C。在 C++ 中,在处理低级内存业务的 罕见 情况下,您将使用 new
而不是 malloc
,而 类 像std::string
或 std::vector
更高级别。
不过,让我们看看这里出了什么问题。
最明显的问题是alocareV
和citireV
之间没有联系,alocareM
/citireM
也一样。您的分配函数的结果 被丢弃 。您必须使用结果:
v = alocareV(n);
a = alocareM(m, p);
alocareM
也有错误。当你为双指针分配内存时,你应该使用sizeof(float*)
,而不是sizeof(float)
。
下一个错误在 citireV
。 scanf_s
要求您传递指向要写入的对象的指针。但是,*(v + i)
会生成 float
,而不是 float*
,因为您取消引用了指针。正确的调用是:
scanf_s("%f", (v + i));
citireM
有完全相同的错误。正确的调用应该是:
scanf_s("%f", ( *(a + i) + j ) );
最后,main
必须returnint
。 void main
在 C 或 C++ 中是不合法的。
这应该可以解决问题。