Opaque Types in Swift Explained (2023) - iOS

แชร์
ฝัง
  • เผยแพร่เมื่อ 7 ม.ค. 2025

ความคิดเห็น • 27

  • @iOSAcademy
    @iOSAcademy  ปีที่แล้ว +3

    Follow for more linkedin.com/in/afrazsiddiqui

  • @lindsaymcrory4215
    @lindsaymcrory4215 ปีที่แล้ว +7

    Nice! I like the clear explanations and focus on a specific topic in digestible time.

    • @iOSAcademy
      @iOSAcademy  ปีที่แล้ว

      Glad it was helpful!

  • @attaliabrown6164
    @attaliabrown6164 9 หลายเดือนก่อน

    This helped alot! Thanks!

    • @iOSAcademy
      @iOSAcademy  9 หลายเดือนก่อน

      Glad it helped!

  • @rahuljamba5846
    @rahuljamba5846 ปีที่แล้ว

    Great !! thanks for sharing.

  • @arseniikovalenko899
    @arseniikovalenko899 ปีที่แล้ว +2

    I have read somewhere that in future swift versions there will be compiler warning when you are using protocol types (ex. in method params, inits, etc.) you should specify keyword any. This warning is a result of dispatch types and it helps helps the developer understand performance degradation.
    So we can use generics while using protocols.
    Example:
    protocol MyProtocol {}
    1. func doSomething(message: MyProtocol) {}
    2. func doSomething(message: T) where T: MyProtocol {}
    3. func doSomething(message: some MyProtocol) {}
    This looks like the same, but it isn't. 2nd and 3rd do the same thing using static dispatch, unlike 1st, that uses dynamic dispatch.
    So, the question is, if I'm correct, do you know about it and should we use some keyword to all protocol types even without associated types?

  • @milindntrivedi
    @milindntrivedi ปีที่แล้ว

    Thank you for the simple explanation much appreciated. Was banging head across room cause of it, read many times couldn't understand the practical use

  • @byaruhaf
    @byaruhaf ปีที่แล้ว

    Thanks for this video, can you make a video on the problem with using any rather than some

  • @kangdeveloper82
    @kangdeveloper82 ปีที่แล้ว +1

    appreciate 🎉

  • @nobodynotcoolbutnice7032
    @nobodynotcoolbutnice7032 ปีที่แล้ว

    谢谢,这是一个非常有用的视频。

  • @olegkaliuzhnyi8722
    @olegkaliuzhnyi8722 ปีที่แล้ว

    Thank you for the video! The docs say all of the possible return values must have the same type. However I saw a SwiftUI example which returns different types and that gets compiled successfully.
    struct Navigation: View where Content: View {
    @ViewBuilder var content: () -> Content
    var body: some View {
    if #available(iOS 16, *) {
    return NavigationStack(root: content)
    } else {
    return NavigationView(content: content)
    }
    }
    }
    Could you explain why that works or point me out to some resources with a good explanation? It's been a week trying to understand it...

    • @olegkaliuzhnyi8722
      @olegkaliuzhnyi8722 ปีที่แล้ว

      Oh I guess I’ve found where to dig next. It seems to be the ViewBuilder which does this magic trick

  • @spixels6880
    @spixels6880 ปีที่แล้ว

    Comparing to Rust, seems like "some" is "impl", and "any" is "dyn"

  • @shurale85
    @shurale85 ปีที่แล้ว

    So the main idea of some is making type erasing easier, isn’t it? But not using diff types in typealias since it will likely brake the execution

  • @victorriurean
    @victorriurean ปีที่แล้ว

    nice

  • @Siberian-Vladik
    @Siberian-Vladik ปีที่แล้ว

    there are saint people. you're definitely one of them