A. C語言宏預編譯中如何將字元串展開
ide 是 vsts 2005 / 2008 的話可以查看預編譯文件
項目屬性頁 - 配置屬性 - c / c++ - 預處理器 - 生成與處理文件 - 是
然後會生成一個後綴名是 .i 的文件,對著 .c .cpp 就可以查看如何展開了。
一般情況下在程序預處理時,一般出現宏名字的地方都用宏定義的字元串替換,然後根據有參數沒有參數進行不同的調用。
B. XCode如何設置預編譯宏
編譯運行都沒問題,但是靜態解析會指出有問題。
正確使用設置預編譯宏的方法是:
2.找到GCC 4.2 Preprocess, 編輯preprocess marco, 預編譯宏
C. 宏編程是什麼
計算機科學里的宏(Macro),是一種批量處理的稱謂。一般說來,宏是一種規則或模式,或稱語法替換 ,用於說明某一特定輸入(通常是字元串)如何根據預定義的規則轉換成對應的輸出(通常也是字元串)。這種替換在預編譯時進行,稱作宏展開。
計算機語言如C語言或 匯編語言有簡單的宏系統,由編譯器或匯編器的預處理器實現。C語言的宏預處理器的工作只是簡單的文本搜索和替換,使用附加的文本處理語言如M4,C程序員可以獲得更精巧的宏。
應用程序也可以使用一種和宏類似機理的系統來允許用戶將一系列(一般是最常使用到的操作)自定義為一個步驟。也就是用戶執行一系列操作,並且讓應用程序來「記住」這些操作以及順序。更高級的用戶可以通過內建的宏編程來來直接使用那些應用程序的功能。
當使用一種不熟悉的宏語言來編程時,比較有效的方法就是記錄一連串用戶希望得到的操作,然後通過閱讀應用程序記錄下來的宏文件來理解宏命令的結構組成。
D. iOS開發 預編譯的宏可以改嗎
iOS開發 預編譯的宏是可以改的。改了不會有什麼問題的
E. 新手求解一道關於【宏定義/預編譯】的很簡單的問題!!!
宏定義是直接代換的
T(a++,a*++b,a+b+c)
被代換成
a++*a+b+c*a*++b/4
即
(a++)*a+b+c*a*(++b)/4
其中b要先自增一
所以,表達式的值為
3*3+4+5*3*4/4=28
a++自增的值是要在本行語句全部執行完後才增加1的
F. c++當中的預編譯宏的問題
#ifndef HY //一般在頭文件都都使用這種格式以防止頭文件在同一文件中被包含兩次。語名#ifndef hyong…..#endi表示僅當以前沒有使用預處理器編譯指令#define定義的名稱hyong時才處理#ifndef….#endif之間的語句。
#define HY //在這里用define定義一個名字HY,以便在下次訪問到該頭文件時,使該名字已經被定義,從而讓程序跳過#ifndef….#endif間的語句。
...
#endif
明白了??
如果還不明白,就下載本人的文章《C++名稱空間與作用域專題》和《C++宏,預處理器,RTTI,typeid與強制類型轉換》去了解了解吧。
G. C語言 宏
難道3不能是字元串嗎?
"3*pi"是字元串,"3"是它的子串。
"3*pi"宏展開後為"3*3.1415926"也是字元串,整個源程序都被認為字元串!
現在,還有有編譯,編譯時,編譯器會把3*3.1415926當表達式計算,用結果再替換一次!
H. c語言gdb調試時怎麼看預編譯宏是否定義
gdb 看不了任何與宏有關的內容。宏在編譯之前,就被預編譯器替換掉了,對於編譯器來說,根本看不到所謂的宏,所以編譯出來的二進制代碼中,也根本不會包含任何宏本身的信息,gdb也自然無法獲取信息了。
I. 宏替換,宏展開到底分別在什麼時候進行
//在宏 使用的時候 分為
宏定義 和 宏展開, 你那個 宏替換就是展開
宏定義是你自己寫的 #define
然後展開在預編譯時候處理
這個時候編譯器先掃描一遍文件 把用到宏的地方都做字元替換
比如
#define M 1
int a = M;
那麼預編譯的時候就把 M 替換成1
注意宏只做文本替換,所以
比如 #define MUL(__x__, __y__) __x__ * __y__
int a = MUL(a + b, c+ d);
會被替換成 int a = a + b * c + d // 可能就會和初衷違背(如果你想做的是 (a + b) * (c + b))
從展開的角度來說 因為宏是可以嵌套的 所以宏在替換的時候 我們叫做展開
比如 做一個函數參數聲明
#define PARAMS_SET_1(__type__, __name__) __type__ __name__
#define PARAMS_SET_2(__type__, __name__) __type__ __name__##1, __type__ __name__##2
//... 定義N個 PARAMS_SET_N
#define PARAMS(__size__, __type__, __name__) PARAMS_SET_##__size__(__type__, __name__)
然後 定義函數
int foo(PARAMS(2, int, n));
那麼預編譯的時候宏會這樣展開
1, int foo(PARAMS_SET_2(int, n));
2, int foo(int n1, int n2);
另外注意就是編程的時候 由於宏只是文本替換,缺少類型檢測 以及運算順序這樣的功能,所以要少用宏
上面所有的宏都有替換的方案
#define M 1 替換方案
struct M
{enum {value = 1} };
int a = M::value;
#define MUL(__x__, __y__) __x__ * __y__ 替換方案
template<int x, int y>
struct MUL
{enum{value = x * y}};
int a = MUL<10 + 20, 10 + 30>::value;
最後一個PARAMS的替換方案就是函數重載
template<typename T>
int foo(T n1);
template<typename T>
int foo(T n1, Tn2);
//後面定義N個