1樓:匿名使用者
#define m 5
#define n 4
#define a m*n
2樓:匿名使用者
原題如下: 以下正確的描述是:在c語言程式中(b )。
a:函式的定義可以巢狀,但函式的呼叫不可以巢狀 b:函式的定義不可以巢狀,但函式的呼叫可以巢狀 c:
函式的定義和函式的呼叫均不可以巢狀 d:函式的定義...
這個巨集定義的函式是什麼意思? 30
3樓:匿名使用者
很難詳細..因為f是個指標..其型別應該是個自定義類
你必須知道f的型別的宣告或註釋..才知道什麼意思
4樓:匿名使用者
就是用這個工具自己編寫一些程式,批處理你的word,excel中的資料,減少你敲擊鍵盤的數量。當然這個功能一般不要用,除非你非常懂~~否則你的word,excel中的資料可鞥會出現不可知的錯誤~~~~
下面是最權威的解釋:
1.不帶引數的巨集定義:
巨集定義又稱為巨集代換、巨集替換,簡稱「巨集」。
格式:#define 識別符號 字串
其中的識別符號就是所謂的符號常量,也稱為「巨集名」。
預處理(預編譯)工作也叫做巨集:將巨集名替換為字串。
掌握"巨集"概念的關鍵是「換」。一切以換為前提、做任何事情之前先要換,準確理解之前就要「換」。
即在對相關命令或語句的含義和功能作具體分析之前就要換:
例:#define pi 3.1415926
把程式中出現的pi全部換成3.1415926
說明:(1)巨集名一般用大寫
(2)使用巨集可提高程式的通用性和易讀性,減少不一致性,減少輸入錯誤和便於修改。例如:陣列大小常用巨集定義
(3)預處理是在編譯之前的處理,而編譯工作的任務之一就是語法檢查,預處理不做語法檢查。
(4)巨集定義末尾不加分號;
(5)巨集定義寫在函式的花括號外邊,作用域為其後的程式,通常在檔案的最開頭。
(6)可以用#undef命令終止巨集定義的作用域
(7)巨集定義可以巢狀
(8)字串" "中永遠不包含巨集
(9)巨集定義不分配記憶體,變數定義分配記憶體。
2.帶引數的巨集:
除了一般的字串替換,還要做引數代換
格式:#define 巨集名(參數列) 字串
例如:#define s(a,b) a*b
area=s(3,2);第一步被換為area=a*b; ,第二步被換為area=3*2;
類似於函式呼叫,有一個啞實結合的過程:
(1)實參如果是表示式容易出問題
#define s(r) r*r
area=s(a+b);第一步換為area=r*r;,第二步被換為area=a+b*a+b;
正確的巨集定義是#define s(r) (r)*(r)
(2)巨集名和引數的括號間不能有空格
(3)巨集替換隻作替換,不做計算,不做表示式求解
(4)函式呼叫在編譯後程式執行時進行,並且分配記憶體。巨集替換在編譯前進行,不分配記憶體
(5)巨集的啞實結合不存在型別,也沒有型別轉換。
(6)函式只有一個返回值,利用巨集則可以設法得到多個值
(7)巨集使源程式變長,函式呼叫不會
(8)巨集不佔執行時間,只佔編譯時間,函式呼叫佔執行時間(分配記憶體、保留現場、值傳遞、返回值)
5樓:戊婧棟合樂
(volatile
uint16
*)0x41ff----轉成指向一個uint16型別的指標(*((volatile
uint16
*)0x41ff))----前面加個*就是指標的表示了一般用在暫存器地址為0x41ff定義上,volatile這個是亮點,注意下
c++ 中define(巨集定義) 各種用法(含特殊),小舉個例子,謝謝!
6樓:會飛的小兔子
1、define是巨集定義,程式在預處理階段將用define定義的內容進行了替換。因此在程式執行時,常量表中並沒有用define定義的常量,系統不為它分配記憶體。而const定義的常量,在程式執行時,存在常量表中,且系統為它分配記憶體。
2、define定義的常量,預處理時只是直接進行了替換,因此在編譯時不能進行資料型別檢驗。而const定義的常量,在編譯時進行嚴格的型別檢驗,可以避免出錯。
3、define定義表示式時要注意「邊緣效應」。
例如:#definen1+2;
floata=n/2.0;
按照常規做法,可能會認為結果是3/2=1.5;
但是實際上,結果應該為1+2/2.0=2.0;
若想要實現3/2,則#definen(1+2);
即為避免邊緣效應,一定要加括號。
擴充套件資料c++巨集定義
#define命令是c++語言中的一個巨集定義命令,它用來將一個識別符號定義為一個字串,該識別符號被稱為巨集名,被定義的字串稱為替換文字。
1、簡單的巨集定義:
#define 《巨集名》 《字串》
例: #define pi 3.14159262、帶引數的巨集定義
#define 《巨集名》 (《參數列》) 《巨集體》
例: #define a(x) x
7樓:湖人總冠軍
1、define是巨集定義,在預處理階段,程式將替換define定義的內容,因此,當程式執行時,常量表中沒有用define定義的常量,系統不會為它分配記憶體,當程式執行時,const定義的常量存在於常量表中,並且系統為它分配記憶體。
2、define定義的常量,只在預處理期間直接替換,因此在編譯期間無法執行資料型別驗證,對於const定義的常量,在編譯時進行嚴格的型別檢查可以避免錯誤。
3、define定義表示式時要注意「邊緣效應」。
例如:#definen1+2;
floata=n/2.0;
按慣例,可認為結果為3/2=1.5;
但實際上,結果應該是1+2/2.0=2.0;
如果你想達到3/2,定義(1+2);
為了避免邊緣效應,必須加括號。
8樓:匿名使用者
1 無參巨集定義
無參巨集的巨集名後不帶引數。
其定義的一般形式為:
#define 識別符號 字串
其中的「#」表示這是一條預處理命令。凡是以「#」開頭的均為預處理命令。「define」為巨集定義命令。「識別符號」為所定義的巨集名。「字串」可以是常數、表示式、格式串等。
在前面介紹過的符號常量的定義就是一種無參巨集定義。此外,常對程式中反覆使用的表示式進行巨集定義。
例如:#define m (y*y+3*y)
它的作用是指定識別符號m來代替表示式(y*y+3*y)。在編寫源程式時,所有的(y*y+3*y)都可由m代替,而對源程式作編譯時,將先由預處理程式進行巨集代換,即用(y*y+3*y)表示式去置換所有的巨集名m,然後再進行編譯。
【例】#define m (y*y+3*y)
main()
上例程式中首先進行巨集定義,定義m來替代表示式(y*y+3*y),在s=3*m+4*m+5* m中作了巨集呼叫。在預處理時經巨集後該語句變為:
s=3*(y*y+3*y)+4*(y*y+3*y)+5*(y*y+3*y);
但要注意的是,在巨集定義中表示式(y*y+3*y)兩邊的括號不能少。否則會發生錯誤。如當作以下定義後:
#difine m y*y+3*y
在巨集時將得到下述語句:
s=3*y*y+3*y+4*y*y+3*y+5*y*y+3*y;
這相當於:
3y2+3y+4y2+3y+5y2+3y;
顯然與原題意要求不符。計算結果當然是錯誤的。因此在作巨集定義時必須十分注意。應保證在巨集代換之後不發生錯誤。
對於巨集定義還要說明以下幾點:
1) 巨集定義是用巨集名來表示一個字串,在巨集時又以該字串取代巨集名,這只是一種簡單的代換,字串中可以含任何字元,可以是常數,也可以是表示式,預處理程式對它不作任何檢查。如有錯誤,只能在編譯已被巨集後的源程式時發現。
2) 巨集定義不是說明或語句,在行末不必加分號,如加上分號則連分號也一起置換。
3) 巨集定義必須寫在函式之外,其作用域為巨集定義命令起到源程式結束。如要終止其作用域可使用# undef命令。
例如:#define pi 3.14159
main()
#undef pi
f1()
表示pi只在main函式中有效,在f1中無效。
4) 巨集名在源程式中若用引號括起來,則預處理程式不對其作巨集代換。
【例】#define ok 100
main()
上例中定義巨集名ok表示100,但在printf語句中ok被引號括起來,因此不作巨集代換。程式的執行結果為:ok這表示把「ok」當字串處理。
5) 巨集定義允許巢狀,在巨集定義的字串中可以使用已經定義的巨集名。在巨集時由預處理程式層層代換。
例如:#define pi 3.1415926
#define s pi*y*y /* pi是已定義的巨集名*/
對語句:
printf("%f",s);
在巨集代換後變為:
printf("%f",3.1415926*y*y);
6) 習慣上巨集名用大寫字母表示,以便於與變數區別。但也允許用小寫字母。
7) 可用巨集定義表示資料型別,使書寫方便。
例如:#define stu struct stu
在程式中可用stu作變數說明:
stu body[5],*p;
#define integer int
在程式中即可用integer作整型變數說明:
integer a,b;
應注意用巨集定義表示資料型別和用typedef定義資料說明符的區別。
巨集定義只是簡單的字串代換,是在預處理完成的,而typedef是在編譯時處理的,它不是作簡單的代換,而是對型別說明符重新命名。被命名的識別符號具有型別定義說明的功能。
請看下面的例子:
#define pin1 int *
typedef (int *) pin2;
從形式上看這兩者相似, 但在實際使用中卻不相同。
下面用pin1,pin2說明變數時就可以看出它們的區別:
pin1 a,b;在巨集代換後變成:
int *a,b;
表示a是指向整型的指標變數,而b是整型變數。
然而:pin2 a,b;
表示a,b都是指向整型的指標變數。因為pin2是一個型別說明符。由這個例子可見,巨集定義雖然也可表示資料型別, 但畢竟是作字元代換。在使用時要分外小心,以避出錯。
8) 對「輸出格式」作巨集定義,可以減少書寫麻煩。
【例】中就採用了這種方法。
#define p printf
#define d "%d\n"
#define f "%f\n"
main()
2 帶參巨集定義
c++語言允許巨集帶有引數。在巨集定義中的引數稱為形式引數,在巨集呼叫中的引數稱為實際引數。
對帶引數的巨集,在呼叫中,不僅要巨集,而且要用實參去代換形參。
帶參巨集定義的一般形式為:
#define 巨集名(形參表) 字串
在字串中含有各個形參。
帶參巨集呼叫的一般形式為:
巨集名(實參表);
例如:#define m(y) y*y+3*y /*巨集定義*/
……k=m(5); /*巨集呼叫*/
……在巨集呼叫時,用實參5去代替形參y,經預處理巨集後的語句為:
k=5*5+3*5
【例】#define max(a,b) (a>b)?a:b
main()
上例程式的第一行進行帶參巨集定義,用巨集名max表示條件表示式(a>b)?a:b,形參a,b均出現在條件表示式中。
程式第七行max=max(x,y)為巨集呼叫,實參x,y,將代換形參a,b。巨集後該語句為:
max=(x>y)?x:y;
用於計算x,y中的大數。
對於帶參的巨集定義有以下問題需要說明:
1. 帶參巨集定義中,巨集名和形參表之間不能有空格出現。
例如把:
#define max(a,b) (a>b)?a:b
寫為:#define max (a,b) (a>b)?a:b
將被認為是無參巨集定義,巨集名max代表字串 (a,b) (a>b)?a:b。巨集時,巨集呼叫語句:
max=max(x,y);
將變為:
max=(a,b)(a>b)?a:b(x,y);
這顯然是錯誤的。
2. 在帶參巨集定義中,形式引數不分配記憶體單元,因此不必作型別定義。而巨集呼叫中的實參有具體的值。
要用它們去代換形參,因此必須作型別說明。這是與函式中的情況不同的。在函式中,形參和實參是兩個不同的量,各有自己的作用域,呼叫時要把實參值賦予形參,進行「值傳遞」。
而在帶參巨集中,只是符號代換,不存在值傳遞的問題。
3. 在巨集定義中的形參是識別符號,而巨集呼叫中的實參可以是表示式。
【例】#define sq(y) (y)*(y)
main()
上例中第一行為巨集定義,形參為y。程式第七行巨集呼叫中實參為a+1,是一個表示式,在巨集時,用a+1代換y,再用(y)*(y) 代換sq,得到如下語句:
sq=(a+1)*(a+1);
這與函式的呼叫是不同的,函式呼叫時要把實參表示式的值求出來再賦予形參。而巨集代換中對實參表示式不作計算直接地照原樣代換。
4. 在巨集定義中,字串內的形參通常要用括號括起來以避免出錯。在上例中的巨集定義中(y)*(y)表示式的y都用括號括起來,因此結果是正確的。如果去掉括號,把程式改為以下形式:
【例】#define sq(y) y*y
main()
執行結果為:
input a number:3
sq=7
我有兩個好朋友,他們都說把我當最好的朋友,但是他們關係並不是很好,所以經常問我是把他當最好的朋友還
小孩子問題,我讀書時候也遇見過這樣的朋友,哎,真煩,我一般都不大理她們!愛幹嘛幹嘛,問我,我就說我當你好朋友就好,你管那麼寬幹嘛 看得懂,他就是比較在乎他在你心中的地位,我也有這樣的朋友。那你就儘可能的讓他們關係好點 我有兩個好朋友,誰來幫我看看我們三的關係,我希望這種友誼能更長久一些。不用執著什麼...
把的兩個音節並組詞,將的多音字怎麼組詞兩個都要
b 1.拿,抓住 酒 拿著酒杯 玩 拿著賞玩 2.控制,掌握 握。舵。3.看守 內 守。門兒容。4.自行車 手推車等的手柄 車 5.可以用手拿的小捆 秫秸 兒。6.專權,一手獨攬 持大權。7.從後托起小孩兩腿使之大小便的動作 尿。8.介詞,義為拿,處置,致使 你能 他怎麼樣。9.量詞。10.結盟 拜...
有兩個孩子以後,你們都是怎麼教育兩個孩子的呢?
我有兩個孩子,都是兒子,一個上小學,一個上幼兒園,所以無論愛哪個,都沒有重男輕女的嫌疑,這讓我放心不少。說到最愛哪個,作為一個媽媽,可以毫不猶豫的說,我兩個都愛,畢竟都是自己懷胎十月,而且手心手背都是肉。古老的教育學家孔子說要因材施教,所以自己的孩子也會根據年齡 性格的差異,給予他們不同的教育和關愛...