青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

醬壇子

專注C++技術 在這里寫下自己的學習心得 感悟 和大家討論 共同進步(歡迎批評!!!)

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  66 Posts :: 16 Stories :: 236 Comments :: 0 Trackbacks

公告

王一偉 湖南商學院畢業 電子信息工程專業

常用鏈接

留言簿(19)

我參與的團隊

搜索

  •  

積分與排名

  • 積分 - 389905
  • 排名 - 64

最新隨筆

最新評論

閱讀排行榜

評論排行榜

自己對 inline 函數做個總結

(一)inline函數(摘自C++ Primer的第三版)

?????????在函數聲明或定義中函數返回類型前加上關鍵字inline即把min()指定為內聯。

?? inline int min(int first, int secend) {/****/};

??????inline函數對編譯器而言必須是可見的,以便它能夠在調用點內展開該函數。與非inline函數不同的是,inline函數必須在調用該函數的每個文本文件中定義。當然,對于同一程序的不同文件,如果inline函數出現的話,其定義必須相同。對于由兩個文件compute.C和draw.C構成的程序來說,程序員不能定義這樣的min()函數,它在compute.C中指一件事情,而在draw.C中指另外一件事情。如果兩個定義不相同,程序將會有未定義的行為:

??????為保證不會發生這樣的事情,建議把inline函數的定義放到頭文件中。在每個調用該inline函數的文件中包含該頭文件。這種方法保證對每個inline函數只有一個定義,且程序員無需復制代碼,并且不可能在程序的生命期中引起無意的不匹配的事情。

(二)內聯函數的編程風格(摘自高質量C++/C 編程指南)

關鍵字inline 必須與函數定義體放在一起才能使函數成為內聯,僅將inline 放在函數聲明前面不起任何作用

如下風格的函數Foo 不能成為內聯函數:inline void Foo(int x, int y); // inline 僅與函數聲明放在一起void Foo(int x, int y){}而如下風格的函數Foo 則成為內聯函數:void Foo(int x, int y);inline void Foo(int x, int y) // inline 與函數定義體放在一起{}所以說,inline 是一種“用于實現的關鍵字”,而不是一種“用于聲明的關鍵字”。一般地,用戶可以閱讀函數的聲明,但是看不到函數的定義。盡管在大多數教科書中內聯函數的聲明、定義體前面都加了inline 關鍵字,但我認為inline 不應該出現在函數的聲明中。這個細節雖然不會影響函數的功能,但是體現了高質量C++/C 程序設計風格的一個基本原則:聲明與定義不可混為一談,用戶沒有必要、也不應該知道函數是否需要內聯。

定義在類聲明之中的成員函數將自動地成為內聯函數,例如class A{public:void Foo(int x, int y) {? } // 自動地成為內聯函數}將成員函數的定義體放在類聲明之中雖然能帶來書寫上的方便,但不是一種良好的編程風格,上例應該改成:// 頭文件class A{public:void Foo(int x, int y);}// 定義文件inline void A::Foo(int x, int y){}?慎用內聯內聯能提高函數的執行效率,為什么不把所有的函數都定義成內聯函數?如果所有的函數都是內聯函數,還用得著“內聯”這個關鍵字嗎?內聯是以代碼膨脹(復制)為代價,僅僅省去了函數調用的開銷,從而提高函數的執行效率。如果執行函數體內代碼的時間,相比于函數調用的開銷較大,那么效率的收獲會很少。另一方面,每一處內聯函數的調用都要復制代碼,將使程序的總代碼量增大,消耗更多的內存空間。以下情況不宜使用內聯:(1)如果函數體內的代碼比較長,使用內聯將導致內存消耗代價較高。(2)如果函數體內出現循環,那么執行函數體內代碼的時間要比函數調用的開銷大。類的構造函數和析構函數容易讓人誤解成使用內聯更有效。要當心構造函數和析構函數可能會隱藏一些行為,如“偷偷地”執行了基類或成員對象的構造函數和析構函數。所以不要隨便地將構造函數和析構函數的定義體放在類聲明中。一個好的編譯器將會根據函數的定義體,自動地取消不值得的內聯(這進一步說明了inline 不應該出現在函數的聲明中)。


注意點:

內聯函數既能夠去除函數調用所帶來的效率負擔又能夠保留一般函數的優點。然而,內聯函數并不是萬能藥, ?
? 在一些情況下,它甚至能夠降低程序的性能。因此在使用的時候應該慎重。 ?
? ? ? ? ? 1.我們先來看看內聯函數給我們帶來的好處:從一個用戶的角度來看,內聯函數看起來和普通函數一樣, ?
? 它可以有參數和返回值,也可以有自己的作用域,然而它卻不會引入一般函數調用所帶來的負擔。另外, ?
? 它可以比宏更安全更容易調試。 ?
? ? 當然有一點應該意識到,inline ? specifier僅僅是對編譯器的建議,編譯器有權利忽略這個建議。那么編譯器是 ?
? ? 如何決定函數內聯與否呢?一般情況下關鍵性因素包括函數體的大小,是否有局部對象被聲明,函數的復雜性等等。 ?
? ? ? ? ? 2.那么如果一個函數被聲明為inline但是卻沒有被內聯將會發生什么呢?理論上,當編譯器拒絕內聯一個 ?
? 函數的時候,那個函數會像普通函數一樣被對待,但是還會出現一些其他的問題。例如下面這段代碼: ?
? // ? filename ? Time.h ?
? #include<ctime> ?
? #include<iostream> ?
? using ? namespace ? std; ?
? class ? Time ?
? { ?
? public: ?
? ? ? ? ? inline ? void ? Show() ? { ? for ? (int ? i ? = ? 0; ? i<10; ? i++) ? cout<<time(0)<<endl;} ?
? }; ?
? ? ? ? ? 因為成員函數Time::Show()包括一個局部變量和一個for循環,所以編譯器一般拒絕inline,并且把它當作一個普通的成員函數。但是這個包含類聲明的頭文件會被單獨的#include進各個獨立的編譯單元中: ?
? ? ? ? ? // ? filename ? f1.cpp ?
? #include ? "Time.hj" ?
? void ? f1() ?
? { ?
? ? ? ? ? Time ? t1; ?
? ? ? ? ? t1.Show(); ?
? } ?
? ?
? // ? filename ? f2.cpp ?
? #include ? "Time.h" ?
? void ? f2() ?
? { ?
? ? ? ? ? Time ? t2; ?
? ? ? ? ? t2.Show(); ?
? } ?
? 結果編譯器為這個程序生成了兩個相同成員函數的拷貝: ?
? void ? f1(); ?
? void ? f2(); ?
? int ? main() ?
? { ?
? ? ? ? ? f1(); ? ?
? ? ? ? ? f2(); ?
? ? ? return ? 0; ?
? } ?
? ?
? 當程序被鏈接的時候,linker將會面對兩個相同的Time::Show()拷貝,于是函數重 ?
? 定義的連接錯誤發生。但是老一些的C++實現對付這種情況的辦法是通過把一個 ?
? un-inlined函數當作static來處理。因此每一份函數拷貝僅僅在自己的編譯單元中 ?
? 可見,這樣鏈接錯誤就解決了,但是在程序中卻會留下多份函數拷貝。在這種情況 ?
? 下,程序的性能不但沒有提升,反而增加了編譯和鏈接時間以及最終可執行體的大小。 ?
? 但是幸運的是,新的C++標準中關于un-inlined函數的說法已經改變。一個符合標準 ?
? C++實現應該只生成一份函數拷貝。然而,要想所有的編譯器都支持這一點可能還 ?
? 需要很長時間。 ?
? 另外關于內聯函數還有兩個更令人頭疼的問題。第一個問題是該如何進行維護。 ?
? 一個函數開始的時候可能以內聯的形式出現,但是隨著系統的擴展,函數體可能要 ?
? 求添加額外的功能,結果內聯函數就變得不太可能,因此需要把inline ? specifier ?
? 去除以及把函數體放到一個單獨的源文件中。另一個問題是當內聯函數被應用在代 ?
? 碼庫的時候產生。當內聯函數改變的時候,用戶必須重新編譯他們的代碼以反映這 ?
? 種改變。然而對于一個非內聯函數,用戶僅僅需要重新鏈接就可以了。 ?
? 這里想要說的是,內聯函數并不是一個增強性能的靈丹妙藥。只有當函數非常短小 ?
? 的時候它才能得到我們想要的效果,但是如果函數并不是很短而且在很多地方都被 ?
? 調用的話,那么將會使得可執行體的體積增大。最令人煩惱的還是當編譯器拒絕內聯 ?
? 的時候。在老的實現中,結果很不盡人意,雖然在新的實現中有很大的改善,但是 ?
? 仍然還是不那么完善的。一些編譯器能夠足夠的聰明來指出哪些函數可以內聯哪些 ?
? 不能,但是,大多數編譯器就不那么聰明了,因此這就需要我們的經驗來判斷。 ?
? 如果內聯函數不能增強行能,就避免使用它! ?
? */ ?
? ?
? /* ?
? 用指針代替數組 ? ?
? 在許多種情況下,可以用指針運算代替數組索引,這樣做常常能產生又快又短的 ?
? 代碼。與數組索引相比,指針一般能使代碼速度更快,占用空間更少。使用多維數 ?
? 組時差異更明顯。下面的代碼作用是相同的,但是效率不一樣。 ?
? ?
? char* ? pBuffer ? = ? new ? char[100]; ?
? nTestNumber ? = ? 0; ?
? ?
? for(dwIndex ? = ? 0;dwIndex ? < ? 100;dwIndex ? ++) ?
? { ?
? nTestNumber ? = ? pBuffer[dwIndex]; ?
? } ?
? ?
? char* ? pTemp ? = ? pBuffer; ?
? for(dwIndex ? = ? 0;dwIndex ? < ? 100;dwIndex ? ++) ?
? { ?
? nTestNumber ? = ? *(pTemp ? ++); ?
? } ?
? ?
? 指針方法的優點是,pBuffer的地址每次裝入地址pTemp后,在每次循環中只需對pTemp增量操作。 ?
? 在數組索引方法中,每次循環中都必須進行基于dwIndex值求數組下標的復雜運算。 ?
? */??

posted on 2006-10-16 20:39 @王一偉 閱讀(9836) 評論(6)  編輯 收藏 引用 所屬分類: 4. C++

Feedback

# re: inline函數 2006-10-29 10:48 Optimistic
inline函數的效率我一直是質疑的 曾經測過100萬次函數調用時INLINE和非INLINE的時間開銷 結果居然INLINE輸了。。。  回復  更多評論
  

# re: inline函數 2006-12-14 10:55 王一偉
啊 哦
我算了1億多次 還是inline強啊
有時候不是寫了inline就一定是inline的:)
你再測試下 看看是不是哪里出了問題
  回復  更多評論
  

# re: inline函數 2007-12-29 17:13 Solomon Joh
可以說明一下什么時候寫了inline就不一定是inline啊?就像聲明寄存器變量不一定在寄存器里?但是寄存器是編譯器負責,inline誰負責啊?  回復  更多評論
  

# re: inline函數 2007-12-30 08:03 @王一偉
呵呵 是的 寄存器變量的分配在編譯時獲得,編譯時會確定變量數據段的地址,包括寄存器變量。

inline也是編譯器負責 原生C++都是在編譯時進行inline化,而C++/CLI可以支持運行時的inline化

不知道是不是可以理解C++/CLI為一種動態語言了 呵呵,我對這不是太清楚 Solomon Jon可以解釋下  回復  更多評論
  

# re: inline函數 2007-12-30 08:12 @王一偉
inline化算是編譯時的一種優化,比如里面有for循環的時候,還有遞歸調用什么的,編譯器就會自動優化成非inline函數,inline的會導致代碼體積上升過快 呵呵。

這個是編譯到代碼段的行為。  回復  更多評論
  

# re: inline函數[未登錄] 2012-05-15 16:42 阿南
說的挺好  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            你懂的网址国产 欧美| 欧美激情综合在线| 亚洲图片欧美午夜| 欧美大胆a视频| 久久网站热最新地址| 国产精品久久久久久久久免费| 免费不卡亚洲欧美| 国内伊人久久久久久网站视频| 一区二区日韩免费看| 亚洲精品美女在线观看播放| 久久久国产精品一区| 久久精品五月婷婷| 国产精品一区二区在线观看网站| 亚洲国产精品一区二区尤物区| 国产亚洲视频在线| 亚洲欧美福利一区二区| 亚洲新中文字幕| 欧美日韩一二三区| 亚洲精品日韩在线| 一区二区免费在线播放| 欧美成人午夜激情在线| 欧美va天堂| 亚洲黄色视屏| 欧美高清一区| 亚洲黄页一区| 一本色道久久88精品综合| 免费观看亚洲视频大全| 欧美第一黄网免费网站| 亚洲国产欧美久久| 欧美成人免费小视频| 最新亚洲激情| 在线综合亚洲| 国产精品盗摄久久久| 亚洲女人天堂av| 久久www免费人成看片高清| 国产一区二区三区久久久久久久久 | 久久国内精品自在自线400部| 国产精品国码视频| 亚洲午夜激情免费视频| 欧美在线播放| 亚洲大片免费看| 欧美激情亚洲另类| 9l视频自拍蝌蚪9l视频成人| 亚洲一区二区三区四区五区黄| 国产精品家庭影院| 欧美一区三区二区在线观看| 另类酷文…触手系列精品集v1小说| 亚洲国产精品尤物yw在线观看| 欧美激情精品久久久久久久变态 | 久久久久综合一区二区三区| 在线观看日韩一区| 欧美精品一区二区三区视频| 亚洲一区二区三区四区在线观看 | 国产性天天综合网| 久久久蜜桃一区二区人| 亚洲激情视频在线| 午夜精品99久久免费| 精品99一区二区三区| 欧美福利视频| 午夜精品福利电影| 欧美成人精精品一区二区频| 国产精品99久久久久久www| 国产日韩一级二级三级| 欧美成人精品一区二区三区| 亚洲一二三区在线| 欧美激情视频一区二区三区不卡| 亚洲香蕉网站| 亚洲黄色av| 国产亚洲综合在线| 欧美日韩1234| 久久久在线视频| 亚洲一区二区三区精品在线观看| 麻豆av福利av久久av| 亚洲欧美高清| 亚洲片区在线| 国产自产v一区二区三区c| 欧美日韩精品二区第二页| 久久九九精品| 亚洲欧美不卡| aaa亚洲精品一二三区| 欧美成人福利视频| 久久经典综合| 亚洲自拍偷拍麻豆| 日韩午夜中文字幕| 伊人久久综合| 国产日韩欧美在线播放不卡| 欧美日韩精品免费观看视频完整 | 国产精品久久久久久久午夜| 免费亚洲电影在线| 久久精品国产在热久久| 午夜精品亚洲| 亚洲手机视频| 在线一区观看| 99re6这里只有精品| 亚洲福利视频网站| 欧美成人免费在线视频| 久久久99久久精品女同性| 午夜精品美女自拍福到在线| 宅男噜噜噜66一区二区 | 欧美影院精品一区| 亚洲欧美韩国| 亚洲欧美久久久| 亚洲一区二区三区在线播放| 宅男噜噜噜66国产日韩在线观看| 亚洲精品亚洲人成人网| 亚洲人体偷拍| 99re在线精品| 在线一区观看| 亚洲女人天堂成人av在线| 亚洲性感激情| 亚洲永久免费视频| 午夜精品一区二区三区在线视 | 国产精品久久久久久久久借妻| 欧美日韩四区| 国产精品国产亚洲精品看不卡15 | 欧美国产一区二区| 欧美激情1区| 亚洲欧洲综合| 一区二区三区久久久| 99日韩精品| 亚洲欧美一区二区原创| 欧美在线观看视频一区二区三区| 欧美在现视频| 麻豆成人在线播放| 欧美精品二区| 欧美视频日韩| 国产日韩欧美在线一区| …久久精品99久久香蕉国产| 亚洲精品一区二区在线观看| 在线视频亚洲一区| 欧美一区二区三区免费大片| 久久综合九色综合欧美狠狠| 亚洲激情在线观看| 亚洲视频电影图片偷拍一区| 欧美在线观看www| 免费成人av在线看| 国产精品福利在线| 黑人巨大精品欧美黑白配亚洲| 亚洲韩国精品一区| 亚洲综合欧美日韩| 久热re这里精品视频在线6| 亚洲成色777777在线观看影院| 99国产精品久久久久老师| 午夜国产精品影院在线观看 | 久久精品免费| 欧美日韩国产限制| 国产亚洲欧洲| 一区二区三区免费在线观看| 欧美在线在线| 亚洲精品久久在线| 欧美一区二区三区在线免费观看 | 亚洲欧美日韩综合一区| 欧美sm视频| 亚洲欧美自拍偷拍| 欧美韩国日本一区| 国产一区二区三区电影在线观看 | 亚洲区第一页| 久久精品国产精品| 欧美三级在线| 亚洲国产91| 久久激情一区| 在线一区视频| 欧美日本高清| 亚洲高清自拍| 久久久人成影片一区二区三区观看| 亚洲国产精品激情在线观看| 欧美专区福利在线| 国产精品国产三级国产a| 有码中文亚洲精品| 亚洲欧美日韩天堂一区二区| 美女视频黄 久久| 香蕉av福利精品导航| 欧美黄色影院| 狠狠色狠狠色综合系列| 午夜精品视频在线观看| 欧美国产日韩在线观看| 亚洲欧美日韩精品久久亚洲区| 香蕉久久国产| 国产精品黄页免费高清在线观看| 亚洲国产日韩欧美在线99| 小黄鸭精品aⅴ导航网站入口| 日韩一级在线观看| 免费亚洲电影在线观看| 国产亚洲激情| 亚洲深夜福利在线| 亚洲人体影院| 免费在线成人av| 国产主播一区二区| 久久久久久国产精品一区| 一本色道久久99精品综合| 久久综合国产精品| 亚洲高清久久| 玖玖国产精品视频| 亚洲欧美日韩网| 欧美三级第一页| 亚洲一区二区三区四区五区黄| 亚洲激情综合| 久久夜色精品国产噜噜av| 在线精品国产欧美| 久久女同互慰一区二区三区|