C++中const與#define的利弊分析
C++中const與#define的區(qū)別如下:
用#define MAX 255定義的常量是沒(méi)有類型的,所給出的是一個(gè)立即數(shù),編譯器只是把所定義的常量值與所定義的常量的名字聯(lián)系起來(lái),define所定義的宏變量在預(yù)處理的時(shí)候進(jìn)行替換,在程序中使用到該常量的地方都要進(jìn)行拷貝替換;
用const float MAX = 255; 定義的常量有類型名字,存放在內(nèi)存的靜態(tài)區(qū)域中,在程序運(yùn)行過(guò)程中const變量只有一個(gè)拷貝,而#define 所定義的宏變量卻有多個(gè)拷貝,所以宏定義在程序運(yùn)行過(guò)程中所消耗的內(nèi)存要比const變量的大得多;
用define定義的常量是不可以用指針變量去指向的,用const定義的常量是可以用指針去指向該常量的地址的;
用define可以定義一些簡(jiǎn)單的函數(shù),const是不可以定義函數(shù)的.
const和#define的利弊,從而推導(dǎo)const的意義;
const和#define都有類似的功能,那就是定義一個(gè)“常量”;
想用來(lái)替換#define定義常量這種方式。這是一種定義宏的方式。因?yàn)楹晏鎿Q定義常量有一定的缺陷:不做類型檢查,沒(méi)有作用域限制(這樣很容易被后續(xù)污染)。
#include#includeusingnamespacestd;voidmyfunc1(){#definea 10}voidmyfunc2(){printf("a=%d\n", a);}intmain(){printf("外面打?。篴=%d\n", a);myfunc1();myfunc2();system("pause");return0;}
因?yàn)橹蛔鲎置嫔系闹苯犹鎿Q,全局都有效,所以無(wú)論定義在哪里,全局都可以訪問(wèn)。因?yàn)槭窃陬A(yù)編譯的時(shí)候就替換好了(只要有定義,就在預(yù)編譯的時(shí)候進(jìn)行全程替換,所以外面里面都可以訪問(wèn))。
同時(shí),很容易受到污染。
#include#includeusingnamespacestd;#definea 10voidmyfunc1(){#definea 20printf("myfunc1里面的:a=%d\n", a);}voidmyfunc2(){printf("myfunc2里面的:a=%d\n", a);}intmain(){printf("外面打?。篴=%d\n", a);myfunc1();myfunc2();system("pause");return0;}
提示有宏重定義,結(jié)果全部都改變?yōu)樾碌模?/p>
宏的方式相當(dāng)于全局變量,無(wú)論在函數(shù)里還是函數(shù)外命名的時(shí)候都要精心雕琢(有點(diǎn)頭痛),否則很容易在以后新的函數(shù)中不小心被替換掉,這就是為什么用它定義常量都基本上全部大寫(xiě),而變量都弄成小寫(xiě),這樣既然不記得有多少宏名了,也不至于沖突。但是它的全局性還是沒(méi)有解決。
而const因?yàn)橛凶饔糜蛳拗?,解決了污染全局變量的困擾。
下面的程序是不行的:
#include#includeusingnamespacestd;voidmyfunc1(){constinta =20;printf("myfunc1里面的:a=%d\n", a);}voidmyfunc2(){printf("myfunc2里面的:a=%d\n", a);}intmain(){printf("外面打?。篴=%d\n", a);myfunc1();myfunc2();system("pause");return0;}
定義個(gè)全局的只讀變量:
#include#includeusingnamespacestd;constinta =10;voidmyfunc1(){constinta =20;printf("myfunc1里面的:a=%d\n", a);}voidmyfunc2(){printf("myfunc2里面的:a=%d\n", a);}intmain(){printf("外面打印:a=%d\n", a);myfunc1();myfunc2();system("pause");return0;}
里面的既不干擾外面的,還可以有優(yōu)先級(jí)之分,同時(shí)要做全局也可以做全局。
這樣新做的函數(shù)中要想使用a這個(gè)名字了,不用考慮什么,直接用就是了。不會(huì)影響以前外面定義的全局變量a,是不是省事的多啊。
const是只讀變量,本質(zhì)上還是變量,是變量就可以傳遞參數(shù),而const還做類型檢查,所以好處更多,如:做形參,可以接收不同的參數(shù),更靈活。
你不能在里面把我的變量給改了吧,可以傳遞不同的變量,因此就曉得更靈活了;
#include#includeusingnamespacestd;voidmyfunc1(constintk){printf("myfunc1里面的數(shù)據(jù)=%d\n", k);}intmain(){constinta =20;myfunc1(a);constintb =30;myfunc1(b);system("pause");return0;}
const的應(yīng)用:
由于是只讀變量,因此保護(hù)了外面的實(shí)參,外面?zhèn)鬟f實(shí)參進(jìn)來(lái),在函數(shù)體里不能修改。因此讓外面的實(shí)參得到安全性考慮。
#include#includeusingnamespacestd;voidmyfunc1(constint* k){*k =3;printf("myfunc1里面的數(shù)據(jù)=%d\n", k);}intmain(){constinta =20;myfunc1(&a);system("pause");return0;}
宏替換的方式相當(dāng)于弄全局變量,很容易被污染,沒(méi)有作用域限制,做不了優(yōu)先級(jí)區(qū)分。它是在預(yù)編譯的時(shí)候就被替換了。
而const是在編譯的時(shí)候才分配變量,有作用域區(qū)分,和類型一致的安全性檢測(cè),應(yīng)用const來(lái)開(kāi)發(fā)項(xiàng)目更方便靈活...
宏替換定義的是常量,必定全局有效;
const定義的是只讀變量,有作用域之分,可以做全局的,也可以做局部的,還有優(yōu)先級(jí)之分。既方便又安全,可以代替#define了。那為什么都存在?因?yàn)橐捕加泻锰?,只是想拿各自的好處罷了:
宏替換的方式,讓整個(gè)編譯過(guò)程變慢(預(yù)編譯時(shí)間+真正編譯的時(shí)間),但是讓程序運(yùn)行速度變快,因?yàn)樵缫阎苯犹鎿Q好了(宏展開(kāi)),直接運(yùn)行就得了。
const和它相反,整個(gè)編譯時(shí)間少,但是程序運(yùn)行速度慢點(diǎn)了,因?yàn)橐覂?nèi)存空間開(kāi)辟變量...
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)飛機(jī)大戰(zhàn)程序設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)飛機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06C語(yǔ)言堆結(jié)構(gòu)處理TopK問(wèn)題詳解
TopK問(wèn)題即在N個(gè)數(shù)中找出最大的前K個(gè),這篇文章將詳細(xì)講解如何利用小根堆的方法解決TopK問(wèn)題,文中代碼具有一定參考價(jià)值,快跟隨小編一起學(xué)習(xí)一下吧2022-06-06C語(yǔ)言實(shí)現(xiàn)文件讀寫(xiě)操作的幾種常用方法
C語(yǔ)言提供了一系列文件操作函數(shù),使得我們可以通過(guò)程序?qū)ξ募M(jìn)行讀寫(xiě)操作,本文主要介紹了C語(yǔ)言實(shí)現(xiàn)文件讀寫(xiě)操作的幾種常用方法,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03用C語(yǔ)言舉例講解數(shù)據(jù)結(jié)構(gòu)中的算法復(fù)雜度結(jié)與順序表
這篇文章主要介紹了講解數(shù)據(jù)結(jié)構(gòu)中的算法復(fù)雜度結(jié)與順序表的C語(yǔ)言版示例,包括對(duì)時(shí)間復(fù)雜度和空間復(fù)雜度等概念的簡(jiǎn)單講解,需要的朋友可以參考下2016-02-02