• <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>

            學習心得(code)

            superlong@CoreCoder

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              74 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

            公告

            文字可能放在http://blog.csdn.net/superlong100,此處存放代碼

            常用鏈接

            留言簿(4)

            我參與的團隊

            搜索

            •  

            最新隨筆

            最新評論

            • 1.?re: Poj 1279
            • 對于一個凹多邊形用叉積計算面積 后能根據結果的正負來判斷給的點集的時針方向?
            • --bsshanghai
            • 2.?re: Poj 3691
            • 你寫的這個get_fail() 好像并是真正的get_fail,也是說fail指向的串并不是當前結點的子串。為什么要這樣弄呢?
            • --acmer1183
            • 3.?re: HDU2295[未登錄]
            • 這個是IDA* 也就是迭代加深@ylfdrib
            • --superlong
            • 4.?re: HDU2295
            • 評論內容較長,點擊標題查看
            • --ylfdrib
            • 5.?re: HOJ 11482
            • 呵呵..把代碼發在這里很不錯..以后我也試試...百度的編輯器太爛了....
            • --csuft1

            閱讀排行榜

            評論排行榜

            Clang 宏定義初探(一)

            的定義方法是#define
            那么在什么場景下需要用到宏呢?遇到一些重復的東西,簡單的有 for(i = 0; i < n; i ++) 之類的,為了減少繁瑣的編碼,可能使用
            #define FO(i,N) for(i=0;i<N;i++)
            為了增強可讀性,比如說設置一個數組常亮大小,可以使用
            #define N 1001
            宏看起來感覺很好用,但是潛藏了很多問題,在實際使用中需要小心謹慎(當然帶來大部分問題的,還是編碼者自己或者合作方)。
            如,現在要求兩個數的最小值,最初會寫出如下宏:
            #define MIN(A,B) A<B?A:B
            正常情況下也是可以使用無誤的:
            1 #include <stdio.h>
            #define MIN(A,B) A<B?A:B
            int main()
            4 {
            5     int a =5, b =6;
            6     printf("%d", MIN(a, b));
            7 }
            然而,當你發布你的代碼或者很久以后自己再去調用時,可能寫成:
            MIN(a<4?a:5, b)
            看起來也沒啥問題,實際執行一下發現,結果是5,偏離預期!事實上,宏即使單純的代碼展開,當你展開上面的式子之后會發現,實際執行的代碼是
            a<4?a:5<b?a<4?a:5:b
            對于一直用括號來解決優先級問題的我來說,這種展開完全無法理解,于是參看了內核代碼,發現更安全的寫法為:
            #define MIN(A,B) (A)<(B)?(A):(B)
            這種寫法規避了令人厭惡的優先級問題!本以為這樣就完成了一個安全的宏定義,但是事實上還有其他問題!
            float a = 1.0f;
            float b = MIN(a++, 1.5f);
            printf("a=%f, b=%f",a,b);
            神秘的a++,同樣按照剛才的思路展開,因為宏里面會有兩次A的展開,所以a++將被執行兩次,再次偏離預期。對于這種情況,我們需要用到一個GNU C的賦值擴展,即使用({...})的形式。這種形式的語句可以類似shell,在順次執行之后,會將最后一次的表達式的賦值作為返回。舉個簡單的例子,下面的代碼執行完畢后a的值為3,而且b和c只存在于大括號限定的代碼域中:
            int a = ({
                int b = 1;
                int c = 2;
                b + c;
            });
            結果是// => a is 3
            基于這種特性,我們可以在宏里面為每個傳入的參數進行一個拷貝,然后再對拷貝后的參數進行實際的比較運算,那么最終實現了一個比較安全的最小值比較的宏定義:
            #define  min(x,y)  ({                   \  
                typeof(x)  __min1 = (x);        \  
                typeof(y) __min2 = (y);             \  
                (void)  (& __min1 == & __min2);     \  
                __min1 < __min2  ? __min1 :min2})  
            最后這一步跳躍有點大了,首先是 typeof 作用是得到參數的類型,其次是(void) (& __min1 == & __min2);  這個神秘的寫法是為了驗證二者的類型是否一致,當然外側我們確實用了GNU的擴展({...})。
            寫到這里,涉及到了另外兩個問題,GNU擴展是啥?另外我們用宏是為了節省代碼,同時為了省去一些小函數的多次重復調用的參數入棧降低性能的問題,那么內聯函數也有這樣的效果,什么是內聯函數呢?
            posted on 2016-03-08 08:44 superlong 閱讀(892) 評論(0)  編輯 收藏 引用 所屬分類: C
            亚洲伊人久久综合影院| 久久久久无码精品国产不卡| 国产精品成人99久久久久 | 亚洲国产成人久久精品99| 久久久久久无码国产精品中文字幕| 国产高潮久久免费观看| 久久综合五月丁香久久激情| 一本色道久久HEZYO无码| 久久精品国产影库免费看| 久久精品国产亚洲Aⅴ蜜臀色欲| 国产精品久久久久免费a∨| 国产99精品久久| 青青热久久国产久精品| 无码精品久久久久久人妻中字| 蜜桃麻豆www久久| 久久久久亚洲AV成人网人人网站| 国产精品视频久久| 色婷婷久久久SWAG精品| 久久91综合国产91久久精品| 中文成人久久久久影院免费观看| 久久99国产综合精品| 久久精品免费一区二区| 狠狠久久综合| 99久久久精品免费观看国产| 国产精品久久新婚兰兰| 久久本道综合久久伊人| 国产精品久久久久久久久| 18禁黄久久久AAA片| 久久99精品久久久久久齐齐| 国产精品美女久久久久| 伊人久久精品无码av一区| 人人狠狠综合久久亚洲| Xx性欧美肥妇精品久久久久久| 无码AV波多野结衣久久| 麻豆精品久久久久久久99蜜桃| 激情久久久久久久久久| 99久久精品免费看国产免费| 国产精品久久网| 国产精品久久久天天影视| 久久久久99精品成人片欧美 | 国产精品欧美久久久天天影视|