• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            C++分析研究  
            C++
            日歷
            <2014年3月>
            2324252627281
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345
            統計
            • 隨筆 - 92
            • 文章 - 4
            • 評論 - 4
            • 引用 - 0

            導航

            常用鏈接

            留言簿

            隨筆檔案

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             
              1.簡單的宏定義
             
               #define 標識符 替換列表(替換列表可以是數,字符串字面量,標點符號,運算符,標識符,關鍵字,字符常量。注意:替換列表是可以為空的)
             
               典型錯誤:
             
               #define N = 100
             
               int a[N]; /*這樣會成為int a[= 100],這里會處理成為一種標識記號一樣*/
             
               #define N 100;
             
               int a[N]; /*帶分號的定義會成為int a[100;],這是一種很常見的錯誤*/
             
               #define pin (int*);
             
               pin a,b;
             
               int* a,b; /*本意是a和b都是int型指針,但是實際上變成int* a,b;a是int型指針,而b是int型變量。這是應該使用typedef來代替define,這樣a和b就都是int型指針了。*/
             
               典型的使用方法:
             
               使用宏定義我們可以自己根據自己的習慣來定義甚至改變C語言的語法習慣,例如雅思改分
             
               #define BEGIN {
             
               #define END }
             
               int main()BEGIN
             
               printf ("DEFINE----\n");
             
               END
             
               定義一個循環
             
               #define LOOP for(;;)
             
               重新定義數據類型
             
               #define IT int
             
               2.帶參數的宏
             
               #define 標識符(x1,x2,x3...xn) 替換列表 (注意:x1,x2,x3..是宏的參數,標識符和其左括弧之間不能有空格)
             
               使用方法:
             
               #define MAX(x,y) ((x)>(y)?(x):(y))
             
               i=MAX(j+k,m-n);
             
               替換為:
             
               i=MAX((j+k)>(m-n)?(j+k):(m-n));
             
               #define SI_EX(n) ((n)%2==0)
             
               if(SI_EX(i)) i++;
             
               替換為:
             
               if(SI_EX((i)%2==0))
             
               通過以上例子我們可以看出,標識符帶參數(X1,X2,X3.....)在替換時會被替換列表(Y1,Y2,Y3....)對應的替換,但是和順序無關。
             
               3.宏的特殊單行定義
             
               #define A(x) T_##x
             
               #define B(x) #@x
             
               #define C(x) #x
             
               x=1
             
               替換為:
             
               A(1)------> T_1 (T_##x,##符號是記號粘黏符號,將前后的字符粘黏起來。)
             
               B(1)------> '1' ( #@x , #@ 符號會將宏的參數進行字符串字面量化,并且加‘’號)
             
               C(1)------> "1" ( #x ,#符號會將宏的參數進行字符串字面量化,并且加""號)
             
               4.define的多行定義
             
               define可以替代多行的代碼,在每一個換行的時候加上一個"\"
             
               #define MAX(X,Y) do { \
             
               語句1; \
             
               語句2; \
             
               /* 注釋的寫法 */ \
             
               } while(0) /* (no trailing ; ) */ \
             
               5.在大規模的開發過程中,特別是跨平臺和系統的軟件里,define最重要的功能是條件編譯。
             
               #ifdef WINDOWS
             
               ......
             
               ......
             
               #endif
             
               #ifdef LINUX
             
               ......
             
               ......
             
               #endif
             
               可以在編譯的時候通過#define設置編譯環境
             
               6.取消宏
             
               #undef 標識符
             
               7.條件編譯
             
               #ifdef XXX…(#else) … #endif
             
               8.預定義宏
             
               在C語言中收錄了一些有用的宏,這些宏是提供當前編譯信息的。
             
               __LINE__ 被編譯文件的行數
             
               (整型)
             
               __FILE__ 被編譯文件的名字 (字符型)
             
               __DATE__ 編譯日期 (字符型)
             
               __TIME__ 編譯時間 (字符型)
             
               __STDC__ 如果編譯器接受標準C,那么值為1. (整型)
             
               通常我們在編譯的時候我們可以用這些預定義的宏來進行排錯,例如雅思答案
             
               一般情況下,當出現除零的情況時編譯器是沒有提示的,我們可以自定義一個解決辦法。
             
               #define CHECKZERO(divisor)\
             
               if(divisor==0)\
             
               printf("***ATTEMPT TO DIVIDE BY ZERO IN LINE %d of file %s ***\n",__LINE__,__FILE__);\
             
               引用方法
             
               CHECKZERO(j);
             
               k=i/j;
             
            posted on 2013-06-07 17:20 HAOSOLA 閱讀(373) 評論(0)  編輯 收藏 引用
             
            Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
            PK10開獎 PK10開獎
            亚洲天堂久久精品| 亚洲嫩草影院久久精品| 精品熟女少妇AV免费久久| 日韩一区二区三区视频久久| 久久人人爽人人人人爽AV| 伊人久久大香线焦AV综合影院| 国内高清久久久久久| 91精品婷婷国产综合久久| 亚洲伊人久久成综合人影院 | 少妇人妻综合久久中文字幕| 亚洲AV乱码久久精品蜜桃| 久久精品这里只有精99品| 久久福利青草精品资源站免费| 亚洲精品无码久久久久去q| 一本久道久久综合狠狠爱| 97r久久精品国产99国产精| 热re99久久精品国产99热| 精品久久人人妻人人做精品 | 香蕉aa三级久久毛片 | 久久久久人妻一区精品| 亚洲欧美日韩精品久久亚洲区| 久久久久无码精品国产不卡| 成人国内精品久久久久影院VR| 亚洲精品成人久久久| 国产精品久久永久免费| 久久精品国产久精国产果冻传媒 | 91精品国产91久久久久久| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 国产精品99久久久精品无码| 国产叼嘿久久精品久久| 无码人妻少妇久久中文字幕蜜桃 | 秋霞久久国产精品电影院| 亚洲愉拍99热成人精品热久久| 国产日韩久久久精品影院首页| 亚洲国产小视频精品久久久三级| 精品久久久久中文字幕日本| 国产精品亚洲综合久久| 性高湖久久久久久久久AAAAA| 99久久777色| 精品久久久久久无码专区| 久久久久成人精品无码中文字幕 |