淺談關(guān)于C語言中#define的副作用
MFC雖然沒有未來,但是我覺得MFC的思想還是有必要研究研究的,在MFC中或者一些底層代碼的編寫中,宏是相當(dāng)好用的,為什么呢?因?yàn)楹曛皇呛?jiǎn)單的替換,不進(jìn)行類型轉(zhuǎn)換,替換就意味著靈活,而C語言編程的靈魂就是靈活啊。
但是在高級(jí)語言中,甚至C++中,是提倡用const的,不提倡用#define,因?yàn)?define有一定的副作用,玩不好就沒命了。
這里我們討論下#define的副作用。
# include <stdio.h> # include <stdlib.h> # define CALL_WITH_MAX(a,b) f((a)>(b)?(a):(b)) int main(void) { int a = 5; int b = 0; CALL_WITH_MAX(++a,b); CALL_WITH_MAX(++a,b+20); return 0; }
分析:
上面的問題,不知道大家有沒有看出來。
對(duì)于CALL_WITH_MAX(++a,b);
1、a首先加1 ,變成了6
2、再和b進(jìn)行比較,結(jié)果是a大,最后返回的結(jié)果是(++a),又被加1 ,最后的結(jié)果是7
對(duì)于CALL_WITH_MAX(++a,b+20);
1、a首先加1 ,變成了8
2、再和b進(jìn)行比較,結(jié)果是a大,最后返回的結(jié)果是b,此時(shí)的b為20,那么a只加了一次,a的結(jié)果是8
# include <stdio.h> # include <stdlib.h> # define CALL_WITH_MAX(a,b) f((a) > (b) ? (a):(b)) void f(int x) { printf("compare result = %d\n",x); } int main(void) { int a = 5; int b = 0; printf("Initial value a = %d\n",a); CALL_WITH_MAX(++a,b); printf("excute the first a = %d\n\n",a); printf("Initial value a = %d\n",a); CALL_WITH_MAX(++a,b+20); printf("excute the second a = %d\n\n",a); return 0; }
結(jié)果分析如下:
以上所述是小編給大家介紹的關(guān)于C語言中#define的副作用詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Qt實(shí)現(xiàn)制作簡(jiǎn)單的計(jì)算器
計(jì)算器是我們生活中很常見的東西,它可以由多種語言多種方式來實(shí)現(xiàn)。本文主要介紹的是利用Qt實(shí)現(xiàn)的簡(jiǎn)易計(jì)算器的制作,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-12-12實(shí)例講解C++編程中l(wèi)ambda表達(dá)式的使用
這篇文章主要介紹了C++編程中l(wèi)ambda表達(dá)式的使用實(shí)例,lambda表達(dá)式特性的引入在C++11中可謂千呼萬喚始出來,非常重要,需要的朋友可以參考下2016-01-01如何基于 Blueprint 在游戲中創(chuàng)建實(shí)時(shí)音視頻功能
我們?cè)诒疚南葋碇v講如何在 Unreal 中用 Blueprint 快速實(shí)現(xiàn)。稍后會(huì)分享基于 C++的實(shí)現(xiàn)步驟。感興趣的朋友跟隨小編一起看看吧2020-05-05C++實(shí)現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08C語言如何計(jì)算一個(gè)整數(shù)的位數(shù)
這篇文章主要介紹了C語言如何計(jì)算一個(gè)整數(shù)的位數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11C語言實(shí)現(xiàn)經(jīng)典排序算法的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用C語言實(shí)現(xiàn)經(jīng)典排序算法中的冒泡排序、選擇排序、插入排序、希爾排序,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-08-08C++算法之海量數(shù)據(jù)處理方法的總結(jié)分析
本篇文章是對(duì)海量數(shù)據(jù)處理方法進(jìn)行了詳細(xì)的總結(jié)與分析,需要的朋友參考下2013-05-05