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

            厚積薄發(fā),滴水穿石

            搬家到主站了:http://www.cnblogs.com/cokecoffe/
            隨筆 - 45, 文章 - 8, 評(píng)論 - 12, 引用 - 0
            數(shù)據(jù)加載中……

            多繼承

            Objective-C不支持多重繼承,但是我們有方法實(shí)現(xiàn)偽繼承.

            舉個(gè)例子,加入對(duì)象A無(wú)法處理消息fun,而對(duì)象B可以處理,此時(shí)A已經(jīng)繼承于類C,所以此時(shí)A不能再繼承B。我們可以用消息轉(zhuǎn)發(fā)的方式,來(lái)將消息轉(zhuǎn)發(fā)給能夠處理fun消息的對(duì)象B。

            當(dāng)然可以這么實(shí)現(xiàn)

            1 A:

            2 -fun

            3 {

            4 ? ? ? ? if([B respondTo:@selector(fun)])

            5 ? ? ? ? {

            6 ? ? ? ? ? ? ? ? return [B fun];

            7 ? ? ? ? }

            8 ? ? ? ? return self;

            9 }

            這樣簡(jiǎn)單的將消息轉(zhuǎn)發(fā)出去,但是此方式欠妥,特別是當(dāng)很多消息都要A來(lái)處理,但是A又無(wú)法處理的時(shí)候,你需要實(shí)現(xiàn)各種fun來(lái)提供每一種方法處理方式。并且當(dāng)寫下代碼的時(shí)候,所能處理的消息集合也就必須確定下來(lái),也就是說(shuō)是靜態(tài)的。

            有一種解決方案可以解決此問(wèn)題 : forwardInvocation:方法,此方法繼承與NSObject。不過(guò)NSObject中此方法的實(shí)現(xiàn),只是簡(jiǎn)單的調(diào)用了doesNotRecognizeSelector:

            我們要做的是重寫需要轉(zhuǎn)發(fā)消息的類A的forwardInvocation方法,以實(shí)現(xiàn)將消息轉(zhuǎn)發(fā)給能處理fun消息的對(duì)象。

            - (void)forwardInvocation:(NSInvocation *)anInvocation
            {
                if ([B respondsToSelector:[anInvocation selector])
                    [anInvocation B];
                else
                    [super forwardInvocation:anInvocation];
            }

            還有關(guān)鍵一步,是重寫methodSignatureForSelector方法,此方法是在向?qū)ο蟀l(fā)送不能處理的消息的時(shí)候調(diào)用的,此方法可判斷消息fun是否有效注冊(cè)。如果注冊(cè)過(guò)fun,那么則返回fun消息的地址之類的信息,如果無(wú)效則返回nil,那么就crash掉。所以我們要把fun消息注冊(cè)為一個(gè)有效的。

               
            1 - (NSMethodSignature*)methodSignatureForSelector:(SEL)selector
            2 {
            3 NSMethodSignature* signature = [super methodSignatureForSelector:selector];
            4
            5 if (!signature)//如果父類中無(wú)注冊(cè)fun消息,那么將B注冊(cè)
            6 signature = [B methodSignatureForSelector:selector];
            7
            8 return signature;
            9 }

            這樣一來(lái),消息fun將被轉(zhuǎn)發(fā)至B。

            我們來(lái)說(shuō)一下向一個(gè)對(duì)象發(fā)送消息后,系統(tǒng)的處理流程

            1.首先發(fā)送消息[A fun];

            2.系統(tǒng)會(huì)檢查A能否響應(yīng)這個(gè)fun消息,如果能響應(yīng)則A響應(yīng)

            3.如果不能響應(yīng),則調(diào)用methodSignatureForSelector:來(lái)詢問(wèn)這個(gè)消息是否有效,包括去父類中詢問(wèn)。

            4.接著調(diào)用forwardInvocation:此時(shí)步驟三返回nil或者可以處理消息的消息地址。如果nil則crash,如果有可以處理fun消息的地址,那么轉(zhuǎn)發(fā)成功。

            ?

            ?

            posted on 2012-05-23 22:51 Wangkeke 閱讀(2131) 評(píng)論(0)  編輯 收藏 引用 所屬分類: IOS

            久久久精品人妻无码专区不卡| 亚洲国产精品无码久久青草| 久久精品国产亚洲AV高清热| 久久天天躁狠狠躁夜夜躁2O2O | 久久久精品人妻无码专区不卡| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 亚洲女久久久噜噜噜熟女| 久久天天躁狠狠躁夜夜avapp| 天天久久狠狠色综合| 一级做a爰片久久毛片毛片| 久久精品国产亚洲av麻豆色欲 | 久久无码专区国产精品发布| 久久精品黄AA片一区二区三区| 久久久黄片| 办公室久久精品| 久久国产精品久久| 亚洲国产精品无码久久| 久久久久97国产精华液好用吗| 少妇久久久久久被弄高潮| 久久婷婷五月综合成人D啪| 久久大香香蕉国产| 狠狠精品久久久无码中文字幕| 久久久久久极精品久久久| 久久香蕉超碰97国产精品| 国产69精品久久久久久人妻精品| yellow中文字幕久久网| 一级做a爰片久久毛片人呢| 日产精品久久久久久久| 2019久久久高清456| 欧美精品丝袜久久久中文字幕 | 欧美激情精品久久久久久| 情人伊人久久综合亚洲| AV色综合久久天堂AV色综合在 | 看全色黄大色大片免费久久久| 国产精品久久久久久久午夜片 | 久久天天躁狠狠躁夜夜不卡| 久久久久九九精品影院| 久久天天躁狠狠躁夜夜不卡| 日本加勒比久久精品| 国内精品久久久久影院老司 | 麻豆av久久av盛宴av|