在C语言中,如何给函数分配内存?
今天我学到函数指针了我看到书上说指针p可以指向函数的入口地址这些我都理解我想问的是程序在编译完了之后是不是就预先给里面所有的函数分配好了内存呢?虽然没有正式分配但是预备着...
今天我学到 函数指针了
我看到书上说
指针p可以指向函数的入口地址
这些我都理解
我想问的是 程序在编译完了之后 是不是就预先给
里面所有的函数分配好了内存呢? 虽然没有正式分配 但是预备着了
我这样理解对不对啊
#include<stdio.h>
int max(int m, int n);
void main() {
int (*p)(int, int);
int a, b, c;
p = max;
scanf("%d,%d",&a, &b);
c = (*p)(a, b);
printf("%d\n",c);
}
int max(int m, int n) {
return m>n ? m:n;
}
可是我在群里问的时候 有人说不对 说 内存分配是未知的
我觉得虽然没有真正给max分配内存地址 但是应该给他拟定好了 如果不拟定了好了
整个程序执行的时候 max代表的入口地址从何而来啊
我理解的对不对啊
求求各位了 我零基础自学。。。。 拜托了!!!! 展开
我看到书上说
指针p可以指向函数的入口地址
这些我都理解
我想问的是 程序在编译完了之后 是不是就预先给
里面所有的函数分配好了内存呢? 虽然没有正式分配 但是预备着了
我这样理解对不对啊
#include<stdio.h>
int max(int m, int n);
void main() {
int (*p)(int, int);
int a, b, c;
p = max;
scanf("%d,%d",&a, &b);
c = (*p)(a, b);
printf("%d\n",c);
}
int max(int m, int n) {
return m>n ? m:n;
}
可是我在群里问的时候 有人说不对 说 内存分配是未知的
我觉得虽然没有真正给max分配内存地址 但是应该给他拟定好了 如果不拟定了好了
整个程序执行的时候 max代表的入口地址从何而来啊
我理解的对不对啊
求求各位了 我零基础自学。。。。 拜托了!!!! 展开
9个回答
展开全部
函数原型void *malloc (long numbytes)
举例:创建100个字节的内存大小
char *buffer = (char*)malloc(100);
举例:创建100个字节的内存大小
char *buffer = (char*)malloc(100);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一个程序编译成二进制文件(可执行文件或库文件)后,其中某个函数在这个二进制文件中的位置就固定了,当运行这个程序或把这个库加载到内存时,该函数的地址就等于程序或库的起始地址加上该函数在该二进制文件中的偏移量。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的理解很正确。对exe来说,编译完之后,函数的地址空间就已经确定了。实际的内存分配发生在模块被加载的时候(即你运行这个程序的时候)。
对于动态连接库(就是DLL)来说,稍微有点区别。如果模块之间发生地址冲突,操作系统会对dll里的函数地址重定位。
对于动态连接库(就是DLL)来说,稍微有点区别。如果模块之间发生地址冲突,操作系统会对dll里的函数地址重定位。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不知lz有没听说过虚存一说,当源码被编译成二进制文件后,其中的变量,函数的虚拟地址,也就是内存空间中的地址就已确定,在运行时,操作系统为其分配物理内存并添加虚拟地址到物理地址的映射。
再说的多一点,一个进程(运行的程序)可分为若干段:代码段、数据段、堆栈段等,其中函数所操作的空间(也就是局部变量的空间)就位于堆栈段,所谓函数分配内存大小,实际就是堆栈段指针的变化而已。
再说的多一点,一个进程(运行的程序)可分为若干段:代码段、数据段、堆栈段等,其中函数所操作的空间(也就是局部变量的空间)就位于堆栈段,所谓函数分配内存大小,实际就是堆栈段指针的变化而已。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询