在C語言巨集定義中,用識別符號來表示字串

2021-04-19 05:49:59 字數 6540 閱讀 3600

1樓:金色潛鳥

巨集定義 #define n 100

是預編譯命令,它的意思是 對下面程式中出現的 ( token) n 作字元替代,把所有的

n 用專 100 替代後 再進行 編譯屬。 這裡的 100 是一串字元, 而不叫 「字串」,

字串 是 術語,指的是 c/c++ 中的 「字串常量」,即雙引號括起來的一串字元 加 一個不可見的 字串結束符 構成的 物件。

2樓:晉凡邗人

兩個問bai題

一個是如果有du空格,那麼不zhi能用scanf%s,因為這個dao

遇到空格就會終止,無法讀

內入完整容輸入。

需要用gets

第二個,

當出現非法字元,

賦值key=0;後,就應該break

否則下一個字元合法,就會再賦值key=1

事實上,當出現一個非法的情況下,

已經不需要繼續判斷了。

在c語言中 巨集定義是什麼?

3樓:雪人晒太陽

在c語言源程式中,允許用一個識別符號來表示一個字串,稱為巨集,巨集定義是由源程式中的巨集定義命令完成的,巨集替換是由預處理程式自動完成的。巨集定義是c提供的三種預處理功能的其中一種,這三種預處理包括:巨集定義、檔案包含、條件編譯。

4樓:仁昌居士

c語言中的巨集定義用法分為兩種。

1、不帶引數的巨集定義比較簡單,就是用一個指定的識別符號來代表一個字串。它的一般形式為「#define 識別符號 字串」,例如#define e 2.718281828459。

這種方法使使用者能以一個簡單的名字代替一個長的字串。

2、帶引數的巨集定義不是僅僅進行簡單的字串替換,還要進行引數替換。其定義的一般形式為;「#define 識別符號(巨集名)(參數列) 字串」,字串中包含在括號中所指定的引數。例如#define s(a,b) a*b area=s(3.

2)。

c語言中的「巨集」是指什麼?

5樓:加百列

巨集是一種預處理指令,它提供了一種機制,可以用來替換源**中的字串。

1、條件編譯:

c語言中,預處理過程讀入源**,檢查包含預處理指令的語句和巨集定義,並對源**進行相應的轉換,預處理過程還會刪除程式中的註釋和多餘的空白符號。

預處理指令是以#開頭的**行,#必須是該行除了空白字元外的第一個字元。#後是指令關鍵字,在#和指令關鍵字之間允許存在若干空白字元。

使用巨集進行條件編譯的用法與使用巨集防止多重引用類似。示例如下:

使用條件編譯,方便程式設計師在除錯程式的過程中,執行一些在程式釋出後並不需要執行的指令。只要在需要除錯的**前加上_debug的定義,就可以在除錯程式的過程中輸出除錯資訊。

這樣方便檢視程式在執行過程中有沒有出現錯誤,定位錯誤出現的地方。而在程式釋出之前,取消_debug的定義就可以不再執行除錯**。

2、巨集函式:

函式的呼叫是需要一定的時間和空間代價的。因為系統在呼叫函式時,需要保留"現場",即將程式要執行的指令的下一條指令的位置壓入棧,然後轉入呼叫函式去執行,呼叫完函式後再返回主調函式,恢復"現場",返回到棧裡儲存的的下一條指令的位置繼續執行。

所以函式的呼叫需要額外的時間和空間代價。

而巨集函式則不存在上述問題,巨集函式在預編譯時,同函式定義的**來替換函式名,將函式**段嵌入到當前程式,不會產生函式呼叫。

所以會省去普通函式保留現場恢復現場的時間,但因為要將定義的函式體嵌入到當前程式,所以不可避免的會佔用額外的儲存空間。

在頻繁呼叫同一個巨集的時候,該現象尤其明顯。巨集函式的示例定義如下:

#define max(a,b) ((a)<(b)?(b):(a))

巨集函式的優點在於避免函式呼叫,提高程式效率。

同時需要注意的是inline識別符號。inline也將函式定義為內聯的。但是使用行內函數需要注意的是:

函式體必須十分簡單,不能含有迴圈、條件、選擇等複雜結構,否則就不能作為行內函數了。

事實上,有時候即便你沒有將函式指定為行內函數,編譯器也會將一些簡單的函式作為行內函數處理,而對於一些複雜的函式,即使宣告為行內函數,編譯器也不會理會的。

inline函式的瓶頸就在於此,使用inline識別符號將函式宣告為內聯的,但這只是一種提示,到底編譯器有沒有優化還依賴於編譯器的實現,而使用巨集函式則完全由**本身控制。

但在使用巨集函式的時候,需要明確的是巨集函式只是簡單的替換,需要注意括號的使用。

擴充套件資料:

巨集的更多規則特性:

(1)巨集名一般用大寫。

(2)使用巨集可提高程式的通用性和易讀性,減少不一致性,減少輸入錯誤和便於修改。例如:陣列大小常用巨集定義。

(3)預處理是在編譯之前的處理,而編譯工作的任務之一就是語法檢查,預處理不做語法檢查。

(4)巨集定義末尾不加分號。

(5)巨集定義寫在函式的花括號外邊,作用域為其後的程式,通常在檔案的最開頭。

(6)可以用#undef命令終止巨集定義的作用域。

(7)巨集定義不可以巢狀。

(8)字串" "中永遠不包含巨集。

(9)巨集定義不分配記憶體,變數定義分配記憶體。

(10)巨集定義不存在型別問題,它的引數也是無型別的。

6樓:榴蓮泡芙小蛋糕

是一種批量處理的稱謂。電腦科學裡的巨集是一種抽象(abstraction),它根據一系列預定義的規則替換一定的文字模式。

「巨集」這個詞的使用暗示著將小命令或動作轉化為一系列指令。

計算機語言如c語言或 組合語言有簡單的巨集系統,由編譯器或彙編器的前處理器實現。c語言的巨集前處理器的工作只是簡單的文字搜尋和替換,使用附加的文字處理語言如m4,c程式設計師可以獲得更精巧的巨集。

在objective-c語言源程式中,允許用一個識別符號來表示一個字串,稱為巨集,被定義為巨集的識別符號稱為巨集名。在編譯預處理時,對程式中所有出現的巨集名,都用巨集定義中的字串去替換,這稱為巨集替換或巨集。

巨集定義是由源程式中的巨集定義命令完成的,巨集替換是由預處理程式自動完成的。在objective-c語言中,巨集分為有引數和無引數兩種。

擴充套件資料

a類巨集是用g65 hxx p#xx q#xx r#xx或g65

hxx p#xx qxx

rxx格式輸入的,xx的意思就是數值,是以um級的量輸入的,比如你輸入100那就是0.1mm #xx就是變數號,變數號就是把數值代入到一個固定的地址中,固定的地址就是變數。

一般otd繫有#0~#100~#149~#500~#531.關閉電源時變數#100~#149被初始化成「空」,而變數#500~#531保持資料。我們如果說#100=30那麼現在#100地址內的資料就是30了。

b類巨集能完成某一功能的一系列指令像子程式那樣存入儲存器,使用者可以設定m、s、t、g**呼叫它們,使用時只需給出這個指令**就能執行其功能,也可以像呼叫子程式一樣使用。

7樓:匿名使用者

簡單來說:巨集定義又稱為巨集代換、巨集替換,簡稱「巨集」。是c提供的三種預處理功能的其中一種。

複雜的請看下面,講的很全。下面的帶參巨集定義,多行巨集定義,在linux核心原始碼中很多。另外sizeof也是一個巨集定義。

巨集定義巨集定義是c提供的三種預處理功能的其中一種,這三種預處理包括:巨集定義、檔案包含、條件編譯

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)巨集不佔執行時間,只佔編譯時間,函式呼叫佔執行時間(分配記憶體、保留現場、值傳遞、返回值)

3. 巨集定義其他冷門、重點知識

#define用法

1、 用無參巨集定義一個簡單的常量

#define len 12

這個是最常見的用法,但也會出錯。

比如下面幾個知識點你會嗎?可以看下:

(1) #define name "zhangyuncong"

程式中有"name"則,它會不會被替換呢?

(2) #define 0x abcd

可以嗎?也就是說,可不可以用把識別符號的字母替換成別的東西?

(3) #define name "zhang

這個可以嗎?

(4) #define name "zhangyuncong"

程式中有上面的巨集定義,並且,程式裡有句:

namelist這樣,會不會被替換成"zhangyuncong"list

四個題答案都是否定的。

第一個,""內的東西不會被巨集替換。這一點應該大都知道。

第二個,巨集定義前面的那個必須是合法的使用者識別符號

第三個,巨集定義也不是說後面東西隨便寫,不能把字串的兩個""拆開。

第四個:只替換識別符號,不替換別的東西。namelist整體是個識別符號,而沒有name識別符號,所以不替換。

也就是說,這種情況下記住:#define 第一位置第二位置

(1) 不替換程式中字串裡的東西。

(2) 第一位置只能是合法的識別符號(可以是關鍵字)

(3) 第二位置如果有字串,必須把""配對。

(4) 只替換與第一位置完全相同的識別符號

還有就是老生常談的話:記住這是簡單的替換而已,不要在中間計算結果,一定要替換出表示式之後再算。

2、 帶參巨集一般用法

比如#define max(a,b) ((a)>(b)?(a):(b))

則遇到max(1+2,value)則會把它替換成:

((1+2)>(value)?(1+2):(value))

注意事項和無參巨集差不多。

但還是應注意

#define fun(a) "a"

則,輸入fun(345)會被替換成什麼?

其實,如果這麼寫,無論巨集的實參是什麼,都不會影響其被替換成"a"的命運。

也就是說,""內的字元不被當成形參,即使它和一模一樣。

那麼,你會問了,我要是想讓這裡輸入fun(345)它就替換成"345"該怎麼實現呢?

請看下面關於#的用法

3、 有參巨集定義中#的用法

#define str(str) #str

#用於把巨集定義中的引數兩端加上字串的""

比如,這裡str(my#name)會被替換成"my#name"

一般由任意字元都可以做形參,但以下情況會出錯:

str())這樣,編譯器不會把「)」當成str()的引數。

str(,)同上,編譯器不會把「,」當成str的引數。

str(a,b)如果實參過多,則編譯器會把多餘的引數捨去。(vc++2008為例)

str((a,b))會被解讀為實參為:(a,b),而不是被解讀為兩個實參,第一個是(a第二個是b)。    4、 有參巨集定義中##的用法

#define wide(str) l##str

則會將形參str的前面加上l

比如:wide("abc")就會被替換成l"abc"

如果有#define fun(a,b) vo##a##b()

那麼fun(id ma,in)會被替換成void main()

5、 多行巨集定義:

#define doit(m,n) for(int i=0;i<(n);++i)\

請選出可用作c語言使用者識別符號的是

所謂識別符號是指常量 變數 語句標號以及使用者自定義函式名稱。c語言規定識別符號只能有數字 字母 下劃線組成,且只能有字母下劃線開頭。不是要記住定義嗎?通過字母,數字,下劃線組成,第一個一定是字母或則下劃線,例如 int a a是合法的,a 548也是合法的,但是48a就不合法了,記得識別符號中只有...

以下不能做C語言使用者識別符號的是,C語言中關鍵字不能作為使用者識別符號嗎

void 這個是c有關鍵字,不能做變數名。define可以做變數名的。識別符號除了你說的那些也外,還不可以是關鍵字,void 是c語言裡的關鍵字,define剛才驗證了一下,可以用作變數 如果選的話,就選void 命名規則 下劃線 a 小寫 a 大寫 上面三種在名稱中可以變成開頭,也可被變數名包含錯...

在c語言中 巨集定義是什麼,在C語言中 巨集定義是什麼?

在c語言源程式中,允許用一個識別符號來表示一個字串,稱為巨集,巨集定義是由源程式中的巨集定義命令完成的,巨集替換是由預處理程式自動完成的。巨集定義是c提供的三種預處理功能的其中一種,這三種預處理包括 巨集定義 檔案包含 條件編譯。c語言中的巨集定義用法分為兩種。1 不帶引數的巨集定義比較簡單,就是用...