95% Don't Understand THIS About Coroutines (Main-Safety)

Поделиться
HTML-код
  • Опубликовано: 11 янв 2025

Комментарии • 80

  • @scottloewke5199
    @scottloewke5199 11 месяцев назад +16

    The rule Philipp refers to is a convention only. It states that a suspend function should never block the calling thread. If we write the suspend function, then the responsibility is ours to ensure that it is main-safe. If we use a 3rd-party suspend function, then it's the responsibility of that developer to abide by the convention. However, it is still our responsibility to ensure (e.g., read the documentation or study the code) that the 3rd-party suspend function follows the convention. In the case of both Retrofit and Room, their documentation states that any suspend functions they generate will be main-safe.

  • @bitwisedevs469
    @bitwisedevs469 Год назад +16

    Always setting the Dispatcher even though we shouldn't is a code smell. Thanks for awesome content

  • @hamedborna7037
    @hamedborna7037 Год назад +8

    Thanks Philipp it was very useful. to me you're the most trustworthy person I've ever seen. I can always rely on your content🤘🏻

  • @bidbid5413
    @bidbid5413 Год назад +7

    Thank you for your videos Philipp! I always learn something new!

  • @eugenepopovich2264
    @eugenepopovich2264 Год назад +4

    You should not catch generic exception in the suspend method, such as coroutine may throw `CancellationException` to interrupt invocation

    • @PhilippLackner
      @PhilippLackner  Год назад +4

      Yes I covered that in a separate video, but I thought not to further overcomplicate this one with an additional non-trivial concept :)

    • @aliaksandrbohush5257
      @aliaksandrbohush5257 Год назад

      If your try-catch block can catch a cancellation exception, then the code is already written incorrectly. The block must catch code exceptions inside the corroutine builder or the block must wrap the topmost corroutine builder - the parent.

    • @aliaksandrbohush5257
      @aliaksandrbohush5257 Год назад

      @@PhilippLackner What is the video?

  • @juanherrera9521
    @juanherrera9521 6 месяцев назад

    withContext just means that everything inside its lambda will be executed in the specified dispatcher, it does no mean that it will magically make the functions called inside of it non-blocking, but it is useful because we can offload the main thread from heavy operations (like an http call or a filesystem operation) and just block a thread on the IO dispatcher instead and then get the result on the calling thread (Main in this case), so it is basically a callback but without the ugliness of it

  • @princeneo294
    @princeneo294 Год назад +3

    Philipp doing what Philipp does, Thanks

  • @johnalejandrogarciaarias9756
    @johnalejandrogarciaarias9756 Год назад +1

    Really useful. Thank you Philipp. Please more videos like this.

  • @TravelVideos1234
    @TravelVideos1234 Год назад +5

    One of the thing to keep in mind is that you should be injecting the dispatcher. That way you can inject test dispatcher while writing unit tests

  • @GS-wf1cp
    @GS-wf1cp 7 месяцев назад

    Mate I can't explain how much I love your content

  • @BharadwajRavinuthala
    @BharadwajRavinuthala Год назад +15

    Philip woke up and decided to show the facts 😅

  • @xemic673
    @xemic673 Год назад

    interesting contents! It was useful tips. Especially 'suspend function call' icon in Android Studio. Thanks philipp

  • @bigman2127
    @bigman2127 Год назад +5

    I agree with all the points provided, but what if a repository method does large mapping stuff / CPU work / multiple calls to Room's DAO? Should i wrap a method with withContext(...) or put withContext(...) inside mappers and DAOs?

    • @PhilippLackner
      @PhilippLackner  Год назад +1

      If mapping is CPU heavy, the mapping function should switch the context to the default dispatcher

    • @Coden55
      @Coden55 Год назад

      @@PhilippLackner why not computation dispatcher?

    • @PhilippLackner
      @PhilippLackner  Год назад +1

      @@Coden55 sorry, typo I correct it. Of course the default one

    • @SerhiiSolodilov
      @SerhiiSolodilov Год назад

      There is no such thing as light computation on UI thread. Any computation on it will result in a frame drop, it just a question when and how many frames will be dropped.

  • @radosawjuszczyk638
    @radosawjuszczyk638 Год назад

    You can use repeat(5) {} instead of that for

  • @Hmmm964
    @Hmmm964 Год назад +2

    Hey, how does retrofit switch to the background thread? Is there any official source that declares that?

  • @marianpazdzioch5437
    @marianpazdzioch5437 11 месяцев назад

    6:43 "even if it would switch to main dispatcher this would not be a problem" how come?

  • @yusuforhan6753
    @yusuforhan6753 Год назад

    Thank you Philipp, your videos are very valuable to us.🎉

  • @nesletchimaew9209
    @nesletchimaew9209 Год назад

    i've been researching coroutine context for the past 5 days 😮

  • @devatrii
    @devatrii Год назад +1

    Can you change that yellow lamp to green one 💚

  • @Daaaaaaavid
    @Daaaaaaavid Год назад +2

    Coroutines and supend functions are the most difficult thing to me to understand since Android 1.x

    • @marianpazdzioch5437
      @marianpazdzioch5437 11 месяцев назад

      Same here. RxJava is easy comparing to coroutines.

  • @raja_uma1r
    @raja_uma1r Год назад

    Amazing content as usual, Consider making a video on how to retrieve data from a suspend function via flow or callback functions.

  • @Revitalish
    @Revitalish 7 месяцев назад

    it wasn't that clear..
    so the coroutine scope should only be written inside a suspend function? not from the repo's function and not from the ViewModel where you call the repo function?

  • @ezzeldin101
    @ezzeldin101 Год назад

    Thanks for the info!

  • @johnkenedy
    @johnkenedy Год назад

    Great video again :3

  • @nomejodas2978
    @nomejodas2978 Год назад

    Why try-catch in the Repository? Adding this error handling logic should be located in the Use Case

  • @mesutemrecelenk5447
    @mesutemrecelenk5447 Год назад

    Thanks phlipp for this useful video. I want to ask a question about this topic. I have a countdown timer in whole app that in activity onCreate. This timer is resetting at user interaction. This timer must be in io thread? Is it necessary?

  • @alexbecar977
    @alexbecar977 Год назад +2

    I'm a little confused sorry, when you say that that the non suspending blocking part of a corutine won't block the underlying thread you mean it won't block the main ui thread right? The IO thread on which the corutine runs on will be blocked by the synchronous code in the coroutine until the coroutine reaches a suspending point?

    • @PhilippLackner
      @PhilippLackner  Год назад +1

      Not the whole thread will be blocked, just the single coroutine. You can launch lots of Coroutines on the same thread which will all run independently

    • @alexbecar977
      @alexbecar977 Год назад

      @@PhilippLackner Thanks a lot

    • @marianpazdzioch5437
      @marianpazdzioch5437 11 месяцев назад

      ​@@PhilippLacknerindependently? You mean concurrently or parallel?

    • @Pavel-wj7gy
      @Pavel-wj7gy 5 месяцев назад

      @@marianpazdzioch5437 Concurrently, not in parallel. Parallel run implies using multiple CPU cores, not threads.

  • @ko3akzhn
    @ko3akzhn Год назад

    When designing a public api, what would be the best approach to let the user know that he don't need to use with Context? Or Public api should be always mainsafe?

    • @PhilippLackner
      @PhilippLackner  Год назад

      That's the concept, the user should be able to rely on your API properly switching the dispatcher

  • @SerhiiSolodilov
    @SerhiiSolodilov Год назад +3

    Tightening yourself to other library implementations isn't a good recommendation.

    • @ahmadhamwi4081
      @ahmadhamwi4081 Год назад

      A small use case that could lead to blocking code inside the library would mess the app up. I agree with you, even though his video is on point.

  • @saeedsharif2463
    @saeedsharif2463 Год назад

    @philip please tell me why jetpack compose fell laggy please one vadeos on this

  • @jimpauloovejera2599
    @jimpauloovejera2599 Год назад

    Hey Phil, do some magic on compose UI!

  • @MisterBPK
    @MisterBPK Год назад

    I faced this problem. Thanks for the detailed video 😍

  • @damercy
    @damercy Год назад

    Is there any downside if we wrap a suspending function with a with context(someDispatcher) anyway? For example: I've a room DAO and in the repository implementation, I wrap my dao call with a with context() block despite knowing room calls are done in background thread.

    • @PhilippLackner
      @PhilippLackner  Год назад +1

      Not a performance downside, but overdoing this makes the code less readable since every withContext adds another indentation and line of code

  • @radosawjuszczyk638
    @radosawjuszczyk638 9 месяцев назад +1

    seeing `for(i in 1 .. 5){}` instead of `repeat(5) {}` hurts my eyes :

  • @GabrielTrifa
    @GabrielTrifa 11 месяцев назад

    excellent video!

  • @nsshurtz
    @nsshurtz Год назад

    So, this information is really useful, however, if every suspend function is supposed to be Main Safe, then why should we not switch off of the main thread ASAP and onto the default thread? After all, if the Main thread is for doing UI work, then why do non-UI work on it?

    • @marianpazdzioch5437
      @marianpazdzioch5437 11 месяцев назад

      Because it would be a nightmare from maintenance of that code point of view.
      Technically you could switch every list iteration to non-main thread but in reality nobody does that.

  • @dvg-in-eu
    @dvg-in-eu Год назад

    But is it a good idea to give this control to retrofit ? I mean, it's retrofit and yes we can trust it, but what we are using other libs which are fetching or doing something isn't it better for us to do this change ourselves?

  • @mitulsheth
    @mitulsheth Год назад

    Very useful and trusted

  • @Naxomiun
    @Naxomiun Год назад +4

    For the people out there: This does not mean that you should not take care of your threads just because there is a call to network through retrofit at the end of your logic. You would end up executing your entire code at the scope default dispatcher; probably Main.Inmediate.

    • @trollberserker1515
      @trollberserker1515 Год назад

      this is absurd situation you imagined
      people do not normally put all blocking logic inside one function terminated with retrofit call.
      you should have your blocking code in separate main-safety functions

    • @Naxomiun
      @Naxomiun Год назад +2

      ​​​@@trollberserker1515what? Its really common to map data models into domain/ui models, merge lists from two endpoints, or just formatting some info before sending it to an endpoint. If you dont handle your threads you'll execute all this logic in your main thread. Its simple to understand. Retrofit switches your dispatcher right before making a net call.

    • @marianpazdzioch5437
      @marianpazdzioch5437 11 месяцев назад

      Still, if those lists are not long (arbitrary, YMMV) then mapping/iterating over them on main thread is acceptable.

  • @Abdulrahman-uk9ny
    @Abdulrahman-uk9ny Год назад

    Can you please record your videos in 4k?

  • @forest__fires
    @forest__fires Год назад +1

    i did not get the point.. please

  • @tegarsubkhanfauzi4641
    @tegarsubkhanfauzi4641 Год назад +2

    Please make a tutorial how to build android tv with jetpack compose.. thaanks ❤❤❤

  • @emmagetsu7369
    @emmagetsu7369 Год назад

    I have a doubt when making a splashscreen when producing on my cell phone, it installs 2 apps, one with the splashscreen and the other with the normal one. And if I uninstall one, both are gone

  • @KaushalDhruw
    @KaushalDhruw Год назад

    Holy cow, I am one of those who used it incorrectly.

  • @tuhinbhowmick8424
    @tuhinbhowmick8424 Год назад

    Nice One

  • @ohiorenuaaigboje7500
    @ohiorenuaaigboje7500 Год назад

    Now i know why my code is lagging

  • @Shubhamkumar-ee8mi
    @Shubhamkumar-ee8mi Год назад +1

    Thank you a lot It will really help me
    But i have one doubt because before that I always switch context to IO in repository.
    It means we dont need to switch context to IO when making http request using retrofit ? Yes or No and explain please

  • @mirniyazulhaque3583
    @mirniyazulhaque3583 Год назад

    Brother teach us backend as well apart from firebase

  • @George-q4z
    @George-q4z Год назад

    😃

  • @giovankabisano2266
    @giovankabisano2266 Год назад