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

            堅持到底就是勝利

            用心去做好這件事情

            統計

            留言簿(1)

            閱讀排行榜

            評論排行榜

            inline

            轉載水木
            誤解:inline函數沒有單獨的函數體,也不能取地址。

            inline修飾并不會改變函數的通常語義,仍可通過函數指針調用:

            inline?void?f()?{}

            void?g()?{
            ??void?(*p)()?=?f;
            ??p();
            }


            ------------------------------------------------------------------------


            誤解:inline一定導致代碼膨脹

            class?Foo?{
            public:
            ????????int?Bar()?{?return?foo;?}
            private:
            ????????int?foo;
            };

            這樣的Foo::Bar?inline會讓binary變小


            ------------------------------------------------------------------------


            誤解:?inline函數一定是internal?linkage/no?linkage的。

            inline與函數的linkage無關。inline函數同樣可以用static和extern修飾,并具
            備同一般函數相同的linkage。標準要求external?linkage的inline函數在所有編
            譯單元中具有相同的地址。external?linkage的inline函數內定義的靜態變量同
            樣應在所有編譯單元中表現為單一對象,具有相同的地址。


            ------------------------------------------------------------------------


            誤解:?如果inline函數包含循環/調用了其他函數/遞歸調用自己,編譯器就無法
            ??????將其展開。

            某些早期的編譯器有這類限制,但對現代編譯器來說它們不再是inline展開的障
            礙了。

            [insert?RoachCock's?example?here]


            ------------------------------------------------------------------------


            誤解:inline和virtual不能同時修飾一個函數。

            inline和virtual并不沖突。以下程序編譯通過。

            #include?<iostream>

            struct?A
            {
            ??inline?virtual?void?f()
            ??{
            ????std::cout?<<?"inline?virtual"?<<?std::endl;
            ??}
            };


            ------------------------------------------------------------------------


            誤解:virtual函數即使聲明為inline,由于是late?binding,無法判斷實際
            ??????調用的版本,編譯器也無法展開。

            虛函數調用并不總是late?binding。

            示例:

            struct?Base
            {
            ??virtual?void?foo(){cout?<<?"Base::foo"?<<?endl;}
            };

            struct?Derived?:?Base
            {
            ??void?foo(){cout?<<?"Derived::foo"?<<?endl;}
            };

            void?bar(Base&?b)
            {
            ??b.foo();??//?late?binding.?if?b?is?a?Derived,?call?Derived::foo
            ??b.Base::foo();??//?early?binding.?inline
            ??Derived?d;
            ??d.foo();??//?early?binding.?inline
            }

            另外,盡管在您的編譯器中很可能還沒有實現,但即使late?binding理論上也是
            可以展開的。

            posted on 2006-07-05 20:10 ailab 閱讀(426) 評論(0)  編輯 收藏 引用

            无码AV中文字幕久久专区| 久久精品成人免费国产片小草| 久久亚洲中文字幕精品一区四| 亚洲伊人久久成综合人影院 | 久久亚洲春色中文字幕久久久| 久久国产热精品波多野结衣AV| 国产精品热久久毛片| 一本色道久久88精品综合| 大美女久久久久久j久久| av色综合久久天堂av色综合在| 国产69精品久久久久99| 性做久久久久久久| 亚洲精品综合久久| 99久久精品毛片免费播放| 久久影院午夜理论片无码| 国产精品99精品久久免费| 久久人做人爽一区二区三区| 狠狠精品干练久久久无码中文字幕| 一本色道久久88—综合亚洲精品| 久久久久亚洲AV成人网| 久久精品一区二区三区不卡| 欧美亚洲国产精品久久| 内射无码专区久久亚洲| 国产精品欧美亚洲韩国日本久久| 久久AV高清无码| 日韩av无码久久精品免费| 777午夜精品久久av蜜臀 | 午夜精品久久久久久久| 亚洲精品乱码久久久久久蜜桃| 久久综合九色综合97_久久久| 久久亚洲精品国产精品| 色偷偷久久一区二区三区| 区久久AAA片69亚洲| 久久久久久久97| 亚洲午夜无码久久久久| 久久久www免费人成精品| 久久精品国产乱子伦| 亚洲AV日韩AV天堂久久| 伊人久久大香线蕉av不变影院 | 三上悠亚久久精品| 一本色道久久88—综合亚洲精品|