1、我想问主函数的执行过程以及调用到子函数时内存除了存储了子函数的返回地址,还存了什么=====》还“保存”了参数,确切的说,是把子函数需要用到的参数
压入到内存栈里面,供子函数调用的时候取
2、子函数的内存里按照内存地址顺序分别存了什么?
===》笼统的讲,里面的变量等
更详细的信息,你可以网络
“函数调用过程详解”
来作深入研究
㈡ C语言:函数的形式参数存放在内存的
形参只是一个符号,不会分配具体的空间的..
当函数被调用的时候,具体给出的参数,也就是实参,其实是一份拷贝..
它的内存空间在该函数的堆中进行分配.
比如
定义函数
int
add(int
,int);
在主函数中
定义变量
int
x,
y..
调用函数
add(x,
y);
那么在函数add的堆中会分配出空间,来保存实参x
y的拷贝..
而主函数中的
x
y
是在主函数的堆中保存的...
不晓得有没有说明白..呵呵
㈢ c语言中 函数调用结束后,函数内定义的静态变量所占用的空间被释放 这句话正确吗求解释
错误!
第一,对于动态存储方式,在函数调用开始时分配动态存储空间,函数结束时释放这些空间,例如传值的函数调用,int x=3,y=4; fun(x,y)//函数里x=4,y=3 ;函数调用结束后释放,main函数仍然是x=3,y=4
第二,在静态存储区内分配的存储单元,在程序整个运行期间都不释放,若非必要,尽量不要静态变量
int main()
{ int f(int);
int a=2,i;
for(i=0;i<3;i++)
printf("%d\n",f(a));
return 0;
}
int f(int a)
{ auto int b=0;//自动局部变量
static c =3;//静态局部变量
b=b+1;
c=c+1;
return(a+b+c);
}
输出为 7(2+1+4) 8(2+1+5) 9(2+1+6)
㈣ C语言调用函数时会为函数分配自己的函数空间吗
C语言每一次函数调用,编译器都会为这个函数调用分配一段空间,这段空间用来存放该函数中的所有局部变量和调用其它函数时需要传递的参数的副本。每一次调用这个函数,这段空间都会重新分配,函数返回后这段空间就被释放了,所以重复调用多少次都不会影响的。所有的这些函数调用时候分配的内存都是在线程的栈上的。
顺便说一下,我觉得楼上的回答是不对的: 每个线程都只会访问自己调用的函数中的局部变量的,访问局部变量是不会存在多线程问题的。会存在多线程问题的肯定不是局部变量,有可能是局部变量指向的其它可共享的对象(例如:堆对象......),或者在函数中访问了全局对象,类的成员变量等,这些并不是局部变量。
㈤ 关于C语言中函数调用时内存管理方面的问题。
一般情况下C里能造成你这种效果的唯一可能就是 malloc之类申请的内存没用free之类释放。非一般情况指你用更底层的方法(比如Windows得HeapAlloc之类)申请内存来着
----
生化的基本原理我倒是还懂的,并且我坚信就算小学没上过自然课的程序员也能看出来你的问题出在哪儿|||
㈥ 关于C语言函数内部内存分配的几个问题~~
1、可以用if代替assert断言。
2、如果空间够,分配就会失败,malloc()会返回一个NULL指针。而free()函数对空指针没有作用(相当于不调用free()函数)
3、如果分配失败,就不用作清理工作(比如调用free()函数)。
㈦ C语言 被调用函数里栈区分配的内存,主调用函数是不能使用的
我是这么理解的,函数调用返回值也会根据类型分配一段内存空间,fun1的返回值类型是int型,程序会分配4个字节用于保存int型的返回值,而a是个整形,它的值在内存释放前赋值拷贝给了返回区空间。
fun2和fun3的返回值类型是char *,程序会分配4个字节的内存空间保存返回值,这个值存储的是一个地址,而 p = “abcde”指向的是常量区,在函数调用结束前将p指向的地址(假如是0X00000111)拷贝给了返回值区间,函数调用结束后虽然释放了局部变量p所占的空间,但函数返回值空间保存的是拷贝过来的地址(依然是0X00000111),而这个地址所指向的内存区并没有释放,所有p可以看到指向的是"abcde"
而fun3拷贝的是局部变量str所存储的地址(假如是0x00002222),函数调用结束时会释放局部变量str的分配的内存,这个时候0x00002222所指向的内容就不确定了,因为它被回收了...所有如果调用fun3,它的返回值是不确定的
㈧ C语言 调用函数完后释放内存吗
肯定会释放了,函数调用完成后,函数里的所有局部变量将会被释放。但是你写的这个程序根本就有问题。你所返回的只是一个地址空间,所以一直没变,释放指的是将这个地址里的内容清除掉,以便使其它的数据可以用这个地址的内存。如果没释放的话,其它的数据就用不了这个址址了。
c的内存泄露主要是出在指针上面。对于变量,系统都会在用完后自动释放的。
㈨ c语言中,函数发生调用时,实参和形参都会占用内存吗
是的,
形参
和
实参
是两个不同的
存储单元
,都占用内存空间,当
函数调用
结束后,形参的内存空间也就会被释放掉了。
㈩ C语言中函数是如何存储的
1. 代码本身是存储在内存的代码段中的,而函数没有说存储的概念,函数调用时是通过栈来实现的。
2.在函数体内声明的变量在默认情况下都是auto存储类型
在代码块之间传递信息的一种方法就是使用外部变量。当一个变量在函数的外部被声明时,安的存储空间是永久分配的,安人存储类型是extren.外部变量的声明看上去和函数或代码块内部所声明的变量一样。外部变量对于它之后的所有函数都有效。在代码块或函数后,外部变量仍然存在。
3.static的基本用途是允许一个局部变量在重新进入代码块时能够保持原来的值。这和自动变量形成了鲜明的对比,自动变量在代码块时会被销毁,再次进入这个代码块时,它必须重新进行初始化。
4.egister存储类型告诉编译器相关的变量应该改量存储在高速度的寄存器中。使用register存储类型的目的一般是为了提高执行速度,但是,register声明只是向编译器所提出的“建议”,并非强制要求。