[swift-users] Attempting to call default protocol implementation crashes Playground
Игорь Никитин
devnikor at icloud.com
Wed Nov 16 00:17:38 CST 2016
And, as I know, it's not possible to call protocol's implementation in that case
> 16 нояб. 2016 г., в 9:09, Игорь Никитин via swift-users <swift-users at swift.org> написал(а):
>
> Right, it’s a recursion, because this
>
> (self as FooPro).fooFunc()
>
> Will call FooClass’s method implementation
>
> You can read more about dispatch rules here: https://medium.com/ios-os-x-development/swift-protocol-extension-method-dispatch-6a6bf270ba94#.hkh1rc56p
>
>
>
>> 16 нояб. 2016 г., в 4:29, Rick Mann via swift-users <swift-users at swift.org> написал(а):
>>
>> Okay. I coudln't find official documentation on this, and I don't currently need to do this, but wanted to fully understand it.
>>
>>> On Nov 15, 2016, at 17:27 , zh ao <owenzx at gmail.com> wrote:
>>>
>>> 'Default' implementation in protocol extension is used as fail safe. You should not consider it like something super class does. If you want it that way, use class inheritance instead.
>>>
>>> Zhaoxin
>>>
>>> Get Outlook for iOS
>>>
>>> _____________________________
>>> From: Rick Mann via swift-users <swift-users at swift.org>
>>> Sent: 星期三, 十一月 16, 2016 07:51
>>> Subject: Re: [swift-users] Attempting to call default protocol implementation crashes Playground
>>> To: Dan Loewenherz <dan at lionheartsw.com>
>>> Cc: swift-users <swift-users at swift.org>
>>>
>>>
>>> Well, this is a standard protocol default implementation. I was experimenting to see if it was possible to call the default implementation after providing a concrete implementation.
>>>
>>>> On Nov 15, 2016, at 14:47 , Dan Loewenherz <dan at lionheartsw.com> wrote:
>>>>
>>>> What are you trying to accomplish here, more concretely?
>>>>
>>>> My first thought is that you shouldn't implement the same function in both a protocol extension and a conforming class. Why not just give them different names and call the function from within the extension instead of from the class? E.g.
>>>>
>>>> protocol FooPro {
>>>> func _fooFunc()
>>>> }
>>>>
>>>> extension FooPro {
>>>> func fooFunc() {
>>>> print("fooFunc default")
>>>> _fooFunc()
>>>> }
>>>> }
>>>>
>>>> class FooClass: FooPro {
>>>> func _fooFunc() {
>>>> print("fooFunc FooClass")
>>>> }
>>>> }
>>>>
>>>> let fc = FooClass()
>>>> fc.fooFunc()
>>>>
>>>> Dan
>>>>
>>>> On Tue, Nov 15, 2016 at 4:28 PM, Rick Mann via swift-users <swift-users at swift.org> wrote:
>>>> The following gives Xcode 8.1 a very hard time. Eventually I get a Bad Access on the last line. I'm guessing it's a recursive call. Is there any way to call the default implementation from a "real" implementation?
>>>>
>>>> protocol FooPro
>>>> {
>>>> func fooFunc()
>>>> }
>>>>
>>>> extension FooPro
>>>> {
>>>> func
>>>> fooFunc()
>>>> {
>>>> print("fooFunc default")
>>>> }
>>>> }
>>>>
>>>> class FooClass : FooPro
>>>> {
>>>> func
>>>> fooFunc()
>>>> {
>>>> (self as FooPro).fooFunc()
>>>> print("fooFunc FooClass")
>>>> }
>>>> }
>>>>
>>>> let fc: FooPro = FooClass()
>>>> fc.fooFunc()
>>>>
>>>>
>>>> Thanks!
>>>>
>>>>
>>>> --
>>>> Rick Mann
>>>> rmann at latencyzero.com
>>>>
>>>>
>>>> _______________________________________________
>>>> swift-users mailing list
>>>> swift-users at swift.org
>>>> https://lists.swift.org/mailman/listinfo/swift-users
>>>>
>>>
>>>
>>> --
>>> Rick Mann
>>> rmann at latencyzero.com
>>>
>>>
>>> _______________________________________________
>>> swift-users mailing list
>>> swift-users at swift.org
>>> https://lists.swift.org/mailman/listinfo/swift-users
>>>
>>>
>>
>>
>> --
>> Rick Mann
>> rmann at latencyzero.com
>>
>>
>> _______________________________________________
>> swift-users mailing list
>> swift-users at swift.org
>> https://lists.swift.org/mailman/listinfo/swift-users
>
> _______________________________________________
> swift-users mailing list
> swift-users at swift.org
> https://lists.swift.org/mailman/listinfo/swift-users
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-users/attachments/20161116/24cfc088/attachment.html>
More information about the swift-users
mailing list