• <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)繼承于類(lèi)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)寫(xiě)下代碼的時(shí)候,所能處理的消息集合也就必須確定下來(lái),也就是說(shuō)是靜態(tài)的。

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

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

               
            1 - (NSMethodSignature*)methodSignatureForSelector:(SEL)selector
            2 {
            3 NSMethodSignature* signature = [super methodSignatureForSelector:selector];
            4
            5 if (!signature)//如果父類(lèi)中無(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)詢(xún)問(wèn)這個(gè)消息是否有效,包括去父類(lèi)中詢(xún)問(wèn)。

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

            ?

            ?

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

            亚洲精品午夜国产va久久| 国内精品久久久久久中文字幕| 国产精品久久免费| 久久久久99精品成人片欧美| 亚洲中文字幕久久精品无码喷水| 婷婷久久综合九色综合九七| 亚洲国产日韩欧美综合久久| 亚洲午夜福利精品久久| 久久亚洲AV成人无码软件| 久久久www免费人成精品| 7777精品伊人久久久大香线蕉| 国产精品美女久久久久AV福利| 日韩精品久久久久久| 久久亚洲国产午夜精品理论片| 88久久精品无码一区二区毛片 | 久久国产成人午夜aⅴ影院| 97超级碰碰碰碰久久久久| 久久亚洲国产成人影院网站| 性高朝久久久久久久久久| 亚洲国产精品无码久久久秋霞2| 97久久久久人妻精品专区| 99久久免费只有精品国产| 亚洲国产成人精品无码久久久久久综合| 久久国产乱子伦精品免费午夜| 精品伊人久久久| 韩国无遮挡三级久久| 久久夜色精品国产| 久久久国产精品亚洲一区| 久久精品国产福利国产琪琪| 亚洲va中文字幕无码久久| 久久福利片| 久久九九精品99国产精品| 久久涩综合| 99精品久久精品一区二区| 一级做a爰片久久毛片免费陪| 大伊人青草狠狠久久| 2021久久精品免费观看| 国产精久久一区二区三区| 中文字幕乱码久久午夜| 欧美亚洲另类久久综合婷婷| 国产成人久久AV免费|