iOS OC內(nèi)聯(lián)函數(shù) inline

inline

在iOS中的一些框架中,static inline是經(jīng)常出現(xiàn)的關(guān)鍵字組合.

  • static自不用多說,表示在當前文件中應(yīng)用,如 static A, 在其它文件中也可以出現(xiàn)static A.不會導(dǎo)致重名的錯誤.
  • inline.內(nèi)聯(lián)函數(shù).
  • 作用:替代宏.

(如果你在看框架時,看到inline不解,搜索到這篇文章,看到這里可以不用看下面的詳述了)

  • 在框架中出現(xiàn)inline時,如YYKit框架.我們稍加觀察就會發(fā)現(xiàn)它出現(xiàn)在.h文件中. such as:
static inline CGFloat CGFloatFromPixel(CGFloat value) {
    return value / YYScreenScale();
}

//YYScreenScale()方法說明:
CGFloat YYScreenScale() {
    static CGFloat scale;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        scale = [UIScreen mainScreen].scale;
    });
    return scale;
}

雖然static inline修飾的是函數(shù)(或者方法,swift出來后,我覺著方法==函數(shù),朋友們不用咬文嚼字,鄙視我輩了).但它在這里就是宏的作用,即你可以將CGFloatFromPixel當作一個宏.
當然inline函數(shù)與宏有區(qū)別,inline可以:

  • 解決函數(shù)調(diào)用效率的問題:
  • 函數(shù)之間調(diào)用,是內(nèi)存地址之間的調(diào)用活翩,當函數(shù)調(diào)用完畢之后還會返回原來函數(shù)執(zhí)行的地址啊胶。函數(shù)調(diào)用有時間開銷,內(nèi)聯(lián)函數(shù)就是為了解決這一問題奇钞。
  • 不用inline修飾的函數(shù), 匯編時會出現(xiàn) call 指令.調(diào)用call指令就是就需要:
    • (1)將下一條指令的所在地址入棧
    • (2)并將子程序的起始地址送入PC(于是CPU的下一條指令就會轉(zhuǎn)去執(zhí)行子程序).

結(jié)論

為什么inline能取代宏?
  • 優(yōu)點相比于函數(shù):

    1. inline函數(shù)避免了普通函數(shù)的,在匯編時必須調(diào)用call的缺點:取消了函數(shù)的參數(shù)壓棧,減少了調(diào)用的開銷,提高效率.所以執(zhí)行速度確比一般函數(shù)的執(zhí)行速度要快.
  • 2)集成了宏的優(yōu)點,使用時直接用代碼替換(像宏一樣);

  • 優(yōu)點相比于宏:

  • 1)避免了宏的缺點:需要預(yù)編譯.因為inline內(nèi)聯(lián)函數(shù)也是函數(shù),不需要預(yù)編譯.

  • 2)編譯器在調(diào)用一個內(nèi)聯(lián)函數(shù)時涯雅,會首先檢查它的參數(shù)的類型,保證調(diào)用正確展运。然后進行一系列的相關(guān)檢查活逆,就像對待任何一個真正的函數(shù)一樣。這樣就消除了它的隱患和局限性拗胜。

  • 3)可以使用所在類的保護成員及私有成員蔗候。

inline內(nèi)聯(lián)函數(shù)的說明
  • 1.內(nèi)聯(lián)函數(shù)只是我們向編譯器提供的申請,編譯器不一定采取inline形式調(diào)用函數(shù).
  • 2.內(nèi)聯(lián)函數(shù)不能承載大量的代碼.如果內(nèi)聯(lián)函數(shù)的函數(shù)體過大,編譯器會自動放棄內(nèi)聯(lián).
  • 3.內(nèi)聯(lián)函數(shù)內(nèi)不允許使用循環(huán)語句或開關(guān)語句.
  • 4.內(nèi)聯(lián)函數(shù)的定義須在調(diào)用之前.

參考資料:

http://stackoverflow.com/questions/11985307/static-extern-and-inline-in-objective-c

http://tigcc.ticalc.org/doc/gnuexts.html#SEC93

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市埂软,隨后出現(xiàn)的幾起案子锈遥,更是在濱河造成了極大的恐慌,老刑警劉巖勘畔,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件所灸,死亡現(xiàn)場離奇詭異,居然都是意外死亡炫七,警方通過查閱死者的電腦和手機爬立,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來万哪,“玉大人侠驯,你說我怎么就攤上這事抡秆。” “怎么了吟策?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵琅轧,是天一觀的道長。 經(jīng)常有香客問我踊挠,道長乍桂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任效床,我火速辦了婚禮睹酌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘剩檀。我一直安慰自己憋沿,他們只是感情好,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布沪猴。 她就那樣靜靜地躺著辐啄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪运嗜。 梳的紋絲不亂的頭發(fā)上壶辜,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天,我揣著相機與錄音担租,去河邊找鬼砸民。 笑死,一個胖子當著我的面吹牛奋救,可吹牛的內(nèi)容都是我干的岭参。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼尝艘,長吁一口氣:“原來是場噩夢啊……” “哼演侯!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起背亥,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤秒际,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后隘梨,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體程癌,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡舷嗡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年轴猎,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片进萄。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡捻脖,死狀恐怖锐峭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情可婶,我是刑警寧澤沿癞,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站矛渴,受9級特大地震影響椎扬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜具温,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一蚕涤、第九天 我趴在偏房一處隱蔽的房頂上張望蹋笼。 院中可真熱鬧嚎幸,春花似錦、人聲如沸柏肪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至峦椰,卻和暖如春龄寞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背汤功。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工萄焦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人冤竹。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓拂封,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鹦蠕。 傳聞我的和親對象是個殘疾皇子冒签,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

推薦閱讀更多精彩內(nèi)容