‘壹’ c语言中如何释放已定义的数组空间
变量用delete释放,数组用delete[]释放,指针的类型不能改变。对于一些简单的情况(所有成员都是基本数据类型,没有析构函数),可以直接用delete释放。
例:
structNODE
{
intidata;
doubleddata;
}node[100];
//释放空间
delete[]node;
//所有的数组类型释放空间都这样写
(1)c语言如何释放多个内存扩展阅读
C语言数组
数组的声明并不是声明一个个单独的变量,比如number0、number1、...、number99,而是声明一个数组变量,比如numbers,然后使用numbers[0]、numbers[1]、...、numbers[99]来代表一个个单独的变量。数组中的特定元素可以通过索引访问。
所有的数组都是由连续的内存位置组成。最低的地址对应第一个元素,最高的地址对应最后一个元素。
‘贰’ 关于C语言中柔性数组内存释放问题
首先,结构体里char * cpArr[0];的意思是分配0个为char *元素的数组,其实就是不分配,所以sizeof (struct testStruct)的值是4
然后,sizeof (struct testStruct) + 3 * sizeof (char *)表示的其实就是4个char*指针所占用的内存空间,也就是4个struct testStruct结构体所占用的内存空间。
这样看来,指针t应该指向的是一个有4个struct testStruct元素的结构体,理论上应该不会导致内存泄漏。
这段代码的大概目的就是打算让struct testStruct结构体的cpArr数组可以有多个,且个数不确定的元素。虽然编译器没有给出警告,但这样的代码是一个很不好的代码——不但降低了可读性,也降低了可靠性。如果你想建立一个struct testStruct结构体的数组,如果直接使用struct testStruct * t = (struct testStruct *) malloc (2*(sizeof (struct testStruct) + 3 * sizeof (char *)));分配内存,那么t[1]->cpArr[0]和t[0]->cpArr[1]将代表同一个值。
建议使用
struct testStruct * t = (struct testStruct *) malloc (sizeof (struct testStruct));
t->cpArr=(char**)malloc(3*sizeof(char*));
来分配内存,使用
free (t->cpArr);
free (t);
来释放内存,char**的意思就是指向char*的指针,为了建立一个char*指针的数组,即字符串数组。而使用时还可以使用t->cpArr[0]、t->cpArr[1]、t->cpArr[2]来表示。即这个程序的代码可以改成
#include<stdio.h>
#include<stdlib.h>
struct testStruct
{
char * c;
char ** cpArr;
};
int main (void)
{
struct testStruct * t = (struct testStruct *) malloc (sizeof (struct testStruct));
t->cpArr=(char**)malloc(3*sizeof(char*));
t->cpArr[0] = "This";
t->cpArr[1] = "is a";
t->cpArr[2] = "test.";
printf ("%s %s %s\n", t->cpArr[0], t->cpArr[1], t->cpArr[2]);
free (t->cpArr);
free (t);
return 0;
}
这样虽然多占了一个char**指针的空间,但会大大增强程序的可读性和可靠性,就不会有问题了。
‘叁’ c语言中,分配的静态数组,如何释放内存
全局数组在程序运行结束时自动释放。
函数内定义的数组在函数退出时自动释放。
C/C++没有提供人为释放办法。
‘肆’ 求解关于C语言的释放内存问题
是InitStack(s)吧?程序里就没有InitSqlist()。
因为栈内容没有初始化,所以访问那个s->top时就出错了,并不是分配内存的malloc的问题。
把主函数里这两行改一下:
Stack *s; /* 这里没有给s分配内存,这只是一个Stack的指针*/
InitStack(s);
改为:
Stack s; /* 这样就给s分配空间了, s.top现在就可以用了*/
InitStack(&s);
这个问题就好了。
相应地,以后使用栈时注意使用指针就好:
ShowStack(s);
改为
ShowStack(&s);
还有一种做法,就是在:
Stack *s;
InitStack(s);
中间给指针s分配内存,让指针s指向正确的结构:
Stack *s;
s = (Stack*)malloc(sizeof(Stack));
InitStack(s);
‘伍’ 内存释放的时候具体进行了什么操作(C语言)
当你用malloc或者calloc申请内存之后,这部分内存会用于存储特定的数据,而无法被其他的变量使用。而当你如果不释放,可能会引起内存占用过多。而如果内存占用过多的话,可能的结果就是电脑瘫痪。这也就是常说的“内存泄漏”。函数原型为:void
free
(void
*
p),一般使用为free(p);(p为指向一个已分配空间的指针)。在执行这个语句时,电脑就可以把这部分内存分配给其他变量。也就算是释放了。