關(guān)于define與C 的內(nèi)存
問題1:#define到底存在程序的哪個區(qū)?
自己寫了一個小程序驗證一下第一個問題。
程序代碼:
<span style="font-size:18px;">#include <stdio.h>
#include <STDLIB.H>
#define kMAX 100
typedef struct {
int ID;
char * name;
}Student;
void test()
{
return;
}
//常量區(qū),靜態(tài)區(qū),堆區(qū),棧區(qū),程序代碼區(qū)
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));//動態(tài)分配內(nèi)存
static int k = 9;
printf("常量區(qū)\n");
printf("const int(%p)\n",&a);
printf("char *(%p)\n",b);
printf("靜態(tài)區(qū)\n");
printf("static int (%p)\n",&k);
printf("堆區(qū)\n");
printf("(int*)malloc(100*sizeof(int))(%p)\n",ap);
printf("棧區(qū)\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("程序代碼區(qū)\n");
printf("test()(%p)\n",test);
printf("未知\n");
printf("define (%p)\n",kMAX);
free(ap);
return 0;
}</span>
發(fā)現(xiàn):
1、通過運行代碼可以看出程序的幾個內(nèi)存區(qū)互不相鄰;
2、#define的內(nèi)存單元在程序運行前已經(jīng)分配。
3、我們知道,char *會存在常量區(qū),但如果我們把char *“封裝”到一個struct里,這時它會同該struct分配到棧區(qū)中,也就是說,我們可以修改struct中char *里的值。
----------------------------------------------------------------------------------------------------------------------------------------------------------
問題2:我們已經(jīng)知道,宏實質(zhì)上是替換,而函數(shù)是傳參,調(diào)用。那么,帶參數(shù)宏與普通函數(shù)在效率上有什么區(qū)別?
通過查閱一些資料了解到
1、普通函數(shù)是在程序運行時調(diào)用,程序會給它的成員分配內(nèi)存。而帶參宏是在編譯前就已經(jīng)執(zhí)行,并且不會分配內(nèi)存單元。
2、宏替換不占用運行時間,只占用編譯時間。函數(shù)則占用運行時間。所以,如果想提高程序運行效率,可以用宏代替部分函數(shù)。
相關(guān)文章
Matlab實現(xiàn)繪制有氣泡感的網(wǎng)絡(luò)圖
這篇文章主要介紹了如何利用Matlab實現(xiàn)繪制有氣泡感的網(wǎng)絡(luò)圖,文中的示例代碼講解詳細,對我們學習Matlab有一定的幫助,需要的可以參考一下2023-02-02

