const和#define的利弊,從而推導(dǎo)const的意義;
const和#define都有類似的功能,那就是定義一個“常量”;
想用來替換#define定義常量這種方式。這是一種定義宏的方式。因為宏替換定義常量有一定的缺陷:不做類型檢查,沒有作用域限制(這樣很容易被后續(xù)污染)。
#include<iostream>#include<string>using namespace std;void myfunc1() {#define a 10}void myfunc2() {printf("a=%d ", a);}int main() {printf("外面打?。篴=%d ", a);myfunc1();myfunc2();system("pause");return 0;}
因為只做字面上的直接替換,全局都有效,所以無論定義在哪里,全局都可以訪問。因為是在預(yù)編譯的時候就替換好了(只要有定義,就在預(yù)編譯的時候進行全程替換,所以外面里面都可以訪問)。
同時,很容易受到污染。
#include<iostream>#include<string>using namespace std;#define a 10void myfunc1() {#define a 20printf("myfunc1里面的:a=%d ", a);}void myfunc2() {printf("myfunc2里面的:a=%d ", a);}int main() {printf("外面打?。篴=%d ", a);myfunc1();myfunc2();system("pause");return 0;}
提示有宏重定義,結(jié)果全部都改變?yōu)樾碌模?/p>
宏的方式相當(dāng)于全局變量,無論在函數(shù)里還是函數(shù)外命名的時候都要精心雕琢(有點頭痛),否則很容易在以后新的函數(shù)中不小心被替換掉,這就是為什么用它定義常量都基本上全部大寫,而變量都弄成小寫,這樣既然不記得有多少宏名了,也不至于沖突。但是它的全局性還是沒有解決。
而const因為有作用域限制,解決了污染全局變量的困擾。
下面的程序是不行的:
#include<iostream>#include<string>using namespace std;void myfunc1() {const int a = 20;printf("myfunc1里面的:a=%d ", a);}void myfunc2() {printf("myfunc2里面的:a=%d ", a);}int main() {printf("外面打?。篴=%d ", a);myfunc1();myfunc2();system("pause");return 0;}
定義個全局的只讀變量:
#include<iostream>#include<string>using namespace std;const int a = 10;void myfunc1() {const int a = 20;printf("myfunc1里面的:a=%d ", a);}void myfunc2() {printf("myfunc2里面的:a=%d ", a);}int main() {printf("外面打?。篴=%d ", a);myfunc1();myfunc2();system("pause");return 0;}
里面的既不干擾外面的,還可以有優(yōu)先級之分,同時要做全局也可以做全局。
這樣新做的函數(shù)中要想使用a這個名字了,不用考慮什么,直接用就是了。不會影響以前外面定義的全局變量a,是不是省事的多啊。
const是只讀變量,本質(zhì)上還是變量,是變量就可以傳遞參數(shù),而const還做類型檢查,所以好處更多,如:做形參,可以接收不同的參數(shù),更靈活。
你不能在里面把我的變量給改了吧,可以傳遞不同的變量,因此就曉得更靈活了;
#include<iostream>#include<string>using namespace std;void myfunc1(const int k) {printf("myfunc1里面的數(shù)據(jù)=%d ", k);}int main() {const int a = 20;myfunc1(a);const int b = 30;myfunc1(b);system("pause");return 0;}
const的應(yīng)用:
由于是只讀變量,因此保護了外面的實參,外面?zhèn)鬟f實參進來,在函數(shù)體里不能修改。因此讓外面的實參得到安全性考慮。
#include<iostream>#include<string>using namespace std;void myfunc1(const int* k) {*k = 3;printf("myfunc1里面的數(shù)據(jù)=%d ", k);}int main() {const int a = 20;myfunc1(&a);system("pause");return 0;}
宏替換的方式相當(dāng)于弄全局變量,很容易被污染,沒有作用域限制,做不了優(yōu)先級區(qū)分。它是在預(yù)編譯的時候就被替換了。
而const是在編譯的時候才分配變量,有作用域區(qū)分,和類型一致的安全性檢測,應(yīng)用const來開發(fā)項目更方便靈活...
宏替換定義的是常量,必定全局有效;
const定義的是只讀變量,有作用域之分,可以做全局的,也可以做局部的,還有優(yōu)先級之分。既方便又安全,可以代替#define了。那為什么都存在?因為也都有好處,只是想拿各自的好處罷了:
宏替換的方式,讓整個編譯過程變慢(預(yù)編譯時間+真正編譯的時間),但是讓程序運行速度變快,因為早已直接替換好了(宏展開),直接運行就得了。
const和它相反,整個編譯時間少,但是程序運行速度慢點了,因為要找內(nèi)存空間開辟變量...