时间:2021-05-02
问题1:#define到底存在程序的哪个区?
自己写了一个小程序验证一下第一个问题。
程序代码:
? 1 2 3 4 5 6 7 8 9 10 11 12 <span style="font-size:18px;">#include <stdio.h> #include <STDLIB.H> #define kMAX 100 typedef struct { int ID; char * name; }Student; void test() { return; }//常量区,静态区,堆区,栈区,程序代码区
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 const int a = 100; char * b = "ok123"; int main() { Student stu = {10,"张三"}; int n = 9999; int *p = &n; int num[10] = {1,2,3,4}; int *ap=(int*)malloc(100*sizeof(int));//动态分配内存 static int k = 9; printf("常量区\n"); printf("const int(%p)\n",&a); printf("char *(%p)\n",b); printf("静态区\n"); printf("static int (%p)\n",&k); printf("堆区\n"); printf("(int*)malloc(100*sizeof(int))(%p)\n",ap); printf("栈区\n"); printf("struct int(%p),struct char *(%p)\n",&stu.ID,&stu.name); printf("int [](%p)\n",num); printf("int *(%p)\n",&p); printf("int(%p)\n",&n); printf("程序代码区\n"); printf("test()(%p)\n",test); printf("未知\n"); printf("define (%p)\n",kMAX); free(ap); return 0; }</span>发现:
1、通过运行代码可以看出程序的几个内存区互不相邻;
2、#define的内存单元在程序运行前已经分配。
3、我们知道,char *会存在常量区,但如果我们把char *“封装”到一个struct里,这时它会同该struct分配到栈区中,也就是说,我们可以修改struct中char *里的值。
----------------------------------------------------------------------------------------------------------------------------------------------------------
问题2:我们已经知道,宏实质上是替换,而函数是传参,调用。那么,带参数宏与普通函数在效率上有什么区别?
通过查阅一些资料了解到
1、普通函数是在程序运行时调用,程序会给它的成员分配内存。而带参宏是在编译前就已经执行,并且不会分配内存单元。
2、宏替换不占用运行时间,只占用编译时间。函数则占用运行时间。所以,如果想提高程序运行效率,可以用宏代替部分函数。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文主要给大家介绍的是关于Require.JS中define定义方式的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:定义简单的键值对define({c
在C还是C++代码中,typedef都使用的很多,在C代码中尤其是多。typedef与#define有些相似,其实是不同的,特别是在一些复杂的用法上,看了网上一
C++中pragmaonce与#ifndef_XXX_H_#define_XXX_H_的区别pragmaonce之前一直用的很好,今天和同事的配合中发现自己没有
c语言define是定义的意思,即将一个变量强制定义为需要的值。 C语言是一门面向过程的计算机编程语言,与C++、Java等面向对象编程语言有所不同。C语言的
vicheck_tomcat_threads.c#include#include#include#defineOK0#defineWARNING1#define