What is the Sendable protocol in Swift? | Swift Concurrency #11

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

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

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

    8:41 - In xCode 14.1 there will only be a warning and not an error.

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

      Update: I think in Swift 6 it will become an error, for now just a warning

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

    bro you are amazing
    Edit: Also sendable acts as a guard for future safery thread checks, is someone ads a var to a sendable without being aware its being used in asyc sendable will alert them.

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

    Thank you as always for your great work Nick!

  • @2689742
    @2689742 8 หลายเดือนก่อน

    Amazing tutorial.Crystal clear.

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

    At 15.00, should that not be a queue.sync? I'm confused whether it should be async or sync. I believe that if you're making it thread-safe, you need to use sync

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

      We almost always want async, since sync can block the thread. In practice, we almost never need to write this code anymore, since we will use Actors instead.

    • @arday8150
      @arday8150 7 วันที่ผ่านมา +2

      I feel like it should be sync too. What if getting name function works before updateName. If we make both sync we ll be sure of the execution order

  • @andresraigoza2082
    @andresraigoza2082 2 ปีที่แล้ว

    Awesome as always. Thank you so much!!!

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

    Your videos are great, do you have a plan to cover Transferable

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

    Awesommmmmme Video! Thank you so much fore great video! A huge Salute to you 999999999999 times! Keep sharing your knowledge & making awesome video! genius!

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

    What is the brand of your keyboard that sound is very impress me

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

      That is a 16” MacBook Pro 😂

    • @pmjss
      @pmjss 2 ปีที่แล้ว

      @@SwiftfulThinking omg 😱

  • @josemanuelortizsanchez4983
    @josemanuelortizsanchez4983 2 ปีที่แล้ว

    Great video, thanks!

  • @lincolndickerson1293
    @lincolndickerson1293 2 ปีที่แล้ว

    Trying to think of a case that a final class would be needed where a struct or actor couldn’t fit the bill. In the unchecked sendable case shown in the video all we are really doing making an understudy, weak actor, aka an novice implementation of thread safe class? What am I missing?

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

    hey vro ...how to make Core Data Entities conforming to Sendable??

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

    Cool!

  • @alexvaiman4966
    @alexvaiman4966 11 หลายเดือนก่อน

    as i said before about mutating.. you must be careful.
    struct MyStruct: Sendable {
    var title: String
    mutating func changeTitle(newTitle: String) {
    title = newTitle
    }
    func unsafe( t: inout MyStruct) {
    t.changeTitle(newTitle: "new title")
    }
    func test() {
    var t = MyStruct(title: "hello")
    unsafe(t: &t)
    print(t.title)
    }
    }

    • @alexvaiman4966
      @alexvaiman4966 11 หลายเดือนก่อน

      This obviously isn't thread-safe.

    • @SwiftfulThinking
      @SwiftfulThinking  11 หลายเดือนก่อน

      @@alexvaiman4966yea I guess I should have been more clear about immutable structs vs mutable structs too

    • @alexvaiman4966
      @alexvaiman4966 11 หลายเดือนก่อน

      @@SwiftfulThinking Actually, I was wrong. When you try to run a mutating struct function in a thread context, you will get an error saying 'Escaping closure captures mutating 'self' parameter.' So, I guess it is not that structs are thread-safe; they just cannot be shared between threads (which is logical, as most structs are created on the stack). Swift is smart, unlike C++, it will not let you do crazy things.