• <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
            激情综合色综合久久综合| 午夜精品久久久久久久无码| 久久91精品国产91| 久久久精品日本一区二区三区| 久久精品无码一区二区无码| 国产欧美久久久精品影院| 久久伊人影视| 思思久久好好热精品国产| 亚洲精品久久久www| 亚洲伊人久久综合影院| 无夜精品久久久久久| 久久无码AV一区二区三区| 思思久久99热只有频精品66| 久久人人爽人人爽人人片AV不 | 欧美日韩成人精品久久久免费看| 精品久久人人妻人人做精品| 久久久久久国产精品美女| 日日狠狠久久偷偷色综合0| 久久久久久久久66精品片| 久久久久亚洲av成人网人人软件| 无码人妻精品一区二区三区久久久 | 国产成人综合久久精品尤物| 精品久久久久久国产三级| 日韩一区二区三区视频久久| 亚洲国产成人久久一区久久| 综合网日日天干夜夜久久| 久久99国产精品久久| 久久久青草青青国产亚洲免观| 久久强奷乱码老熟女网站| 2022年国产精品久久久久| 久久久精品无码专区不卡| 东方aⅴ免费观看久久av| 久久精品免费一区二区三区| 亚洲va久久久久| 久久亚洲精品视频| 精品久久人人爽天天玩人人妻| 欧美黑人又粗又大久久久| 久久精品国产一区二区| 久久久精品2019免费观看| 亚洲精品无码久久毛片| 久久午夜电影网|