91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++中const和#define的利弊探索

發布時間:2020-07-25 02:21:46 來源:網絡 閱讀:474 作者:ningcaichen66 欄目:編程語言

const和#define的利弊,從而推導const的意義;

const和#define都有類似的功能,那就是定義一個“常量”;

想用來替換#define定義常量這種方式。這是一種定義宏的方式。因為宏替換定義常量有一定的缺陷:不做類型檢查,沒有作用域限制(這樣很容易被后續污染)。

#include<iostream>
#include<string>
using namespace std;

void myfunc1() {
#define a 10
}

void myfunc2() {
printf("a=%d\n", a);
}

int main() {
printf("外面打印:a=%d\n", a);
myfunc1();
myfunc2();

system("pause");
return 0;

}
C++中const和#define的利弊探索

因為只做字面上的直接替換,全局都有效,所以無論定義在哪里,全局都可以訪問。因為是在預編譯的時候就替換好了(只要有定義,就在預編譯的時候進行全程替換,所以外面里面都可以訪問)。

同時,很容易受到污染。

#include<iostream>
#include<string>
using namespace std;

#define a 10

void myfunc1() {
#define a 20
printf("myfunc1里面的:a=%d\n", a);
}

void myfunc2() {
printf("myfunc2里面的:a=%d\n", a);
}

int main() {
printf("外面打印:a=%d\n", a);
myfunc1();
myfunc2();

system("pause");
return 0;

}
提示有宏重定義,結果全部都改變為新的:

C++中const和#define的利弊探索

宏的方式相當于全局變量,無論在函數里還是函數外命名的時候都要精心雕琢(有點頭痛),否則很容易在以后新的函數中不小心被替換掉,這就是為什么用它定義常量都基本上全部大寫,而變量都弄成小寫,這樣既然不記得有多少宏名了,也不至于沖突。但是它的全局性還是沒有解決。

而const因為有作用域限制,解決了污染全局變量的困擾。

下面的程序是不行的:

#include<iostream>
#include<string>
using namespace std;

void myfunc1() {
const int a = 20;
printf("myfunc1里面的:a=%d\n", a);
}

void myfunc2() {
printf("myfunc2里面的:a=%d\n", a);
}

int main() {
printf("外面打印:a=%d\n", a);
myfunc1();
myfunc2();

system("pause");
return 0;

}
C++中const和#define的利弊探索

定義個全局的只讀變量:

#include<iostream>
#include<string>
using namespace std;

const int a = 10;
void myfunc1() {
const int a = 20;
printf("myfunc1里面的:a=%d\n", a);
}

void myfunc2() {
printf("myfunc2里面的:a=%d\n", a);
}

int main() {
printf("外面打印:a=%d\n", a);
myfunc1();
myfunc2();

system("pause");
return 0;

}
C++中const和#define的利弊探索

里面的既不干擾外面的,還可以有優先級之分,同時要做全局也可以做全局。

這樣新做的函數中要想使用a這個名字了,不用考慮什么,直接用就是了。不會影響以前外面定義的全局變量a,是不是省事的多啊。

const是只讀變量,本質上還是變量,是變量就可以傳遞參數,而const還做類型檢查,所以好處更多,如:做形參,可以接收不同的參數,更靈活。

你不能在里面把我的變量給改了吧,可以傳遞不同的變量,因此就曉得更靈活了;

#include<iostream>
#include<string>
using namespace std;

void myfunc1(const int k) {
printf("myfunc1里面的數據=%d\n", k);
}

int main() {
const int a = 20;
myfunc1(a);

const int b = 30;
myfunc1(b);

system("pause");
return 0;

}
C++中const和#define的利弊探索

const的應用:

由于是只讀變量,因此保護了外面的實參,外面傳遞實參進來,在函數體里不能修改。因此讓外面的實參得到安全性考慮。

#include<iostream>
#include<string>
using namespace std;

void myfunc1(const int k) {
k = 3;
printf("myfunc1里面的數據=%d\n", k);
}

int main() {
const int a = 20;
myfunc1(&a);

system("pause");
return 0;

}

C++中const和#define的利弊探索
宏替換的方式相當于弄全局變量,很容易被污染,沒有作用域限制,做不了優先級區分。它是在預編譯的時候就被替換了。

而const是在編譯的時候才分配變量,有作用域區分,和類型一致的安全性檢測,應用const來開發項目更方便靈活...

宏替換定義的是常量,必定全局有效;

const定義的是只讀變量,有作用域之分,可以做全局的,也可以做局部的,還有優先級之分。既方便又安全,可以代替#define了。那為什么都存在?因為也都有好處,只是想拿各自的好處罷了:

宏替換的方式,讓整個編譯過程變慢(預編譯時間+真正編譯的時間),但是讓程序運行速度變快,因為早已直接替換好了(宏展開),直接運行就得了。

const和它相反,整個編譯時間少,但是程序運行速度慢點了,因為要找內存空間開辟變量...

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

射阳县| 高安市| 岳西县| 宁南县| 威远县| 涡阳县| 敦煌市| 行唐县| 西峡县| 隆尧县| 新巴尔虎右旗| 金门县| 浦东新区| 南汇区| 娄底市| 华安县| 阳西县| 四川省| 来宾市| 元朗区| 祁门县| 阳信县| 南川市| 宝兴县| 炉霍县| 新丰县| 常德市| 溧阳市| 抚宁县| 渭源县| 资溪县| 库伦旗| 苗栗县| 长垣县| 密山市| 滦平县| 马边| 绵竹市| 建德市| 罗城| 眉山市|