SwiftData Background Tasks: Massively Improve Your Apps Performance | SwiftData Tutorial | #12

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

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

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

    Nice video as always and yes... tutorial about Profile in Instruments!

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

      You got it!

  • @keegan8176
    @keegan8176 3 หลายเดือนก่อน +1

    Thank you 🙌 do you have any videos on how to query it not on the main thread like you mentioned at the end?

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

    Yes! A video 2:50 with that tool with be great.

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

      I got you!!!

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

    Can you expand on the "Write a predicate to fetch data" (to avoid the @Query on the main thread)
    My app uses a LOT of @Querys and the main thread is bogged down!
    I need more speed.
    Thanks!

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

      So you can use something like this www.hackingwithswift.com/quick-start/swiftdata/how-to-create-a-custom-fetchdescriptor
      The only downside is that you'd have to manage refreshing the view yourself etc which the query macro does for you automatically.

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

      @@tundsdev so what do you recommend? I’m only a part-time Programmer/hobbyist.
      I would prefer something simplistic.

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

    Awesome video, thanks! YES! I'd really love to see a tutorial about instruments

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

      You got it!

  • @spaceman2000-i3s
    @spaceman2000-i3s 5 หลายเดือนก่อน

    Excellent video on ModelActor macro. It was very helpful.

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

      Glad it was helpful!

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

    great video, as always. +1 on a video on instruments!! I have a swift data project that is really bogging down when initiating a view that includes a dynamic filter predicate. I have no idea how to troubleshoot. thanks for what you do

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

      Sounds great!

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

    Helpful. Thank you sir !

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

    Thanx for amazing video, but is it working also when i want to update data ?

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

    Yes instruments tutorial!

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

    When you set "Strict Concurrency Check" to "Complete", you will get a warning the message "Non-sendable type returned by call to actor-isolated function cannot cross actor boundary", How can void this.

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

      You need to make your model sendable manually by marking it with the @unchecked Sendable pretty good article explaining it here but it's safe to use this since we don't modify the model across different threads.Here's a simple example below.
      @Model
      class MyModel: @unchecked Sendable {
      }

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

      @@tundsdev Thanks for the explanation.

    • @spaceman2000-i3s
      @spaceman2000-i3s 5 หลายเดือนก่อน +1

      You can fetch using the ModelActor and then stuff a struct with the results and pass that as the struct is Sendable.

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

      @@tundsdev Why is it safe to do this? Aren't SwiftData models thread-unsafe?

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

    Why create an actor who you just reap everything into Task{let modelContext = ModelContext(container) ...} ?

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

      You have to use an actor so you can move it off the main thread and isolate it onto it's own thread which is what I explain in the video around 4:20, the ModelActor property wrapper lets you create a context away for the main one

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

      @@tundsdev Hmm. In my test this also does move the operation to a background thread. I haven't done much with actors yet, so maybe actors are the preferred way to do it anyway. Here is the code the way I mean it:
      Task(priority: .background) {
      let newModelContext = ModelContext(TestApp.sharedModelContainer)
      (0...1000).forEach { index in
      let newItem = TestItem(uuid: UUID())
      newModelContext.insert(newItem)
      }
      try? newModelContext.save()
      }