Full Guide to Jetpack Compose Effect Handlers

Поделиться
HTML-код
  • Опубликовано: 7 авг 2024
  • The new effect handlers in Jetpack Compose can be quite a pain to deal with if you don't fully understand their purpose. However, they're super important to write performant Jetpack Compose code without side-effects.
    This video once and for all goes through all these effect handlers, so you'll know what it's about afterwards.
    ⭐ Get certificates for your future job
    ⭐ Save countless hours of time
    ⭐ 100% money back guarantee for 30 days
    ⭐ Become a professional Android developer now:
    pl-coding.com/premium-courses...
    💻 Let me personally review your code and provide individual feedback, so it won't backfire and cost you a fortune in future:
    elopage.com/s/philipplackner/...
    Subscribe to my FREE newsletter for regular Android, Kotlin & Architecture advice!
    pl-coding.com/newsletter
    Join this channel to get access to perks:
    / @philipplackner
    Regular live codings on Twitch:
    / philipplackner
    Join my Discord server:
    / discord
    Regular programming advice on my Instagram page: / _philipplackner_
    Checkout my GitHub: github.com/philipplackner
    You like my free content? Here you can buy me a coffee:
    www.buymeacoffee.com/philippl...
    00:00 - What is a side-effect?
    03:34 - LaunchedEffect
    09:11 - rememberCoroutineScope
    11:08 - rememberUpdatedState
    13:03 - DisposableEffect
    15:53 - SideEffect
    17:20 - produceState
    19:12 - derivedStateOf
    22:51 - snapshotFlow

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

  • @thegreatwarrior4989
    @thegreatwarrior4989 2 года назад +67

    For me you are the best channel for Android development

    • @PhilippLackner
      @PhilippLackner  2 года назад +6

      Thanks a lot!

    • @bro_chenzox
      @bro_chenzox 2 года назад

      +++++

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

      @@PhilippLackner Thanks to you bro, resourceful people are often bad teachers cause of human nature, you in other hand are damn smart and brilliant in the way you explain

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

      Same for me.. 😂, I think this man deserves half of our salary 😂. Thanks @PhilippLackner!

  • @alindo23
    @alindo23 Год назад +24

    The only 2 I found useful were LaunchedEffect and DisposableEffect. The rest of them were created to make the interviews harder.

  • @re7650
    @re7650 2 года назад +16

    Philipp is forever invited to my home for dinner. Such nice content and delivery.

  • @allanandliftedhands2669
    @allanandliftedhands2669 2 года назад +4

    I always check on my notifications to make sure i did not miss a new video from this guy

  • @kepper103
    @kepper103 11 месяцев назад +1

    THANK YOU SO MUCH, just this afternoon i was duct taping together my own event system from snippets of code i found online, but the one you show in LaunchedEffect part is so much better and cleaner! Thanks! The rest of the video is also great as well!

  • @alihosseinnezhad2957
    @alihosseinnezhad2957 2 года назад +3

    Thank you Philipp , You explain contents with interesting examples.
    Here is one of the best channel for android.
    👏👏

  • @OnlineEntrepreneurTools
    @OnlineEntrepreneurTools Год назад +37

    Thanks for this! Although my mind couldn't absorb any of the discussed effect. Part 1 to 9 is clear and easy to follow as a newbie of Jetpack Compose. This part (Part 10) doesn't have any relevance in almost all discussed subjects in parts 1 to 9 that's why I couldn't comprehend. Maybe this should be moved in a more advanced playlist for compose. I will just skip to the next part hopefully I am not totally lost as I really love the tutorials. I'll take note on this effect handlers and when I got to the point when I already need this subject then I'll just get back here. Thanks Philipp! Cheers!

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

      I had the same feeling!

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

      same kinda difficult... tried finding the prepared code (samples) to go over it... and couldn't find it. The code qould help, thought of buying the premium course, but if I don't understand the frrebee, not sure I will understand the paid course...) having the code wouldn't deter me from purchasing the paid course, maybe it would motivate me more

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

      ​ 😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮

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

      ​@Peter Fraga 😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮ㅣ😅😅😅😅😮😮😅😮ㅣ😮ㅣ😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😅ㅣ😅😮😮😮😮😮😮ㅑ😅😅😅😅😅😅😅😅😮😅😅😅😮😮😮😅😮😅😮😮😮😮😅😅😅😮ㅣ😮😮😅😅😅😅😅😅😅😅😅😅😅😅😅😅😅😅😮😅ㅏ😅😅😅😮😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😅😅😅😅😮ㅣ😮ㅣ😮😮😮😮😮😮😮😅😅😅😅😮😮😮😅😮😮😮😮😅😮😮😅😅😅😮😮😮😮😮😮😮😮😮😮😮😅😅😮😮😮😮😅😮😮😮😮😮😮😮😮😮

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

      😮😮😮😮😮😮😮😮😮😮😮😮😅😮😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😅😅😅😅😅😅😅😅😅😅😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮ㅣ😅😅😮😮😮😮😮😮ㅣ😮😮😮😮😮😮😮😮😅😅😮😅😮😅😅😅😮😮😮😮😮😮😮😮😮😮😮😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😮ㅣ😮😮😮ㅣㅣ😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😅😅😅😅😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮ㅑ😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😅😅😮😮😮😮😅😅😅😅😅😅😅😅😮😮ㅣ😮😮😮ㅣ😮😮ㅣ😮ㅣ😮😮😮😮😮😮😮😮😮😮😮ㅣ😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😅😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😅😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😅😅😅😅ㅣ😮😮
      😮😮😮😮😮😮😮😮😮😮😮😮😮😮😅😮😮😮😮😅😅😅😅😮😮😮😮😮😮😮😅😮😮😮😮😮😮😮😮😮😅😅😮😮😮ㅣ😮

  • @danielkeyes3931
    @danielkeyes3931 2 года назад

    Thanks for the video. I appreciated all the examples and the simplicity of them for easier understandability.

  • @GakisStylianos
    @GakisStylianos 2 года назад +15

    Just be careful, think of derivedStateOf just as you would mutableStateOf in a sense that it needs to be remembered! Otherwise this isn't remembered and in case of recomposition will just be called again from scratch. And overall it feels like your explanation on derivedStateOf could be improved a bit. You didn't mention anything about how it implicitly "subscribes" to the state objects that are being accessed in there, but doesn't have any mechanism to update itself when non-state objects are being read in its lambda are changed so it would then show stale data.
    I really suggest people to read the excellent documentation on these, it does a great job explaining with examples how they work.

  • @vedx
    @vedx 2 года назад +4

    I was struggling with this. Thanks for the video ❤️❤️

  • @AhsanAli-vz6mg
    @AhsanAli-vz6mg 2 года назад

    Seriously I was waiting for this video
    Thanks 😊

  • @Soulcybering
    @Soulcybering 2 года назад

    Thank you for the video. I will watch all the Compose serie 👍

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

    Gem's channel , thanx man , wish you all the best in your life

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

    Thanks for sharing, really cool video!

  • @t_regbs
    @t_regbs 2 года назад

    thank you so much for this

  • @original_anu
    @original_anu 2 года назад

    Thanks a lot for this ❤️
    I'll bookmark it for future reference :P

  • @cristianovecchi
    @cristianovecchi 2 года назад

    Great! So much useful!

  • @skandarsouissi7282
    @skandarsouissi7282 2 месяца назад

    I def needed this

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

    thanks for all

  • @abdelsttarahmed8821
    @abdelsttarahmed8821 2 года назад

    Really Amaizing video , thank you 😎

  • @nCodeLab
    @nCodeLab 2 года назад

    quality videos after long time ......need more clean architecture full apps tutorial or compose tutorial..(animation ,canvas ,custom modifiers , custom layout..etc)

  • @mukuljangir9162
    @mukuljangir9162 2 года назад +1

    Philip You are Hero

  • @dev_jeongdaeri
    @dev_jeongdaeri 2 года назад

    Super awesome!!

  • @themisterravenous1785
    @themisterravenous1785 2 года назад +1

    awesome video! just one simple thing I notest was he snapshotFlow using the distincUntilChanged(), actually the snapshotFlow itself is already handling it, so it will get the latest value of the state if its value is different, so in this case you dont need call the distinctUntilChanged. btw thanks a lot for this video it helped a lot to understand all of them

  • @The-Fuse
    @The-Fuse 2 года назад +1

    Thank you philipp 😁

  • @MetehanBOLAT
    @MetehanBOLAT 2 года назад +2

    You are the few youtube channels that I have turned on notifications on :D You touch on very important points as always. Thanks.

  • @fawazmn_071
    @fawazmn_071 2 года назад

    Omg thanks very much ! ✨

  • @mustafaammar551
    @mustafaammar551 2 года назад

    very cool video thank you bro

  • @michaberkowicz8239
    @michaberkowicz8239 2 года назад +1

    Compose related videos always welcome

  • @JamesBond-mq7pd
    @JamesBond-mq7pd 4 месяца назад

    wow. such a good explanation.

  • @original_anu
    @original_anu 2 года назад

    Months later, my webview was playing audio event after navigating away. Destroying it in DisposableEffect did the trick.
    Good thing I bookmarked this video 😁

  • @x32gx
    @x32gx 2 года назад +1

    Hi Phillipp!! As always, top notch videos! Thank you! I have a question, I have a Composable function that creates a JFreeChart object which basically gets recomposed when ever its DataSet values are updated. But in that case, the entire JFreeChart object gets recreated again and again with each recomposition. So it appears to be a side effect. Is LaunchedEffect the more accurate choice to prevent that? Do I create the JFreeChart object with key1 = true and then simply let it observe its DataSet updates? Thanks!

  • @user-gi4no6gn7m
    @user-gi4no6gn7m 2 года назад

    As always Sir Philipp is here to save the day

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

    Philipp, Hi! I love your content, thank you for that. I don't understand one thing. Could you please explain me ? Why cant we just use derivedStateOf everywhere since it optimizes everything ?

  • @iftak01
    @iftak01 Месяц назад

    Best explanation video of this thanks bias god

  • @linmaung
    @linmaung 2 года назад

    Love that content...

  • @bro_chenzox
    @bro_chenzox 2 года назад

    Cool episode! Which one of dark themes plugin do you use?

  • @ubersticks
    @ubersticks 2 года назад +2

    Hi Philip - excellent again! How about a quickie example explaining delegation ("by") and when to use that. I find it very confusing and maybe you could shine some light on this.

    • @PhilippLackner
      @PhilippLackner  2 года назад

      Thanks for the idea, however right now i have tons of other videos in my pipeline 😄

  • @be_like__prateek
    @be_like__prateek 2 года назад

    Respect++ 🔥🚀

  • @ShivamVermaokdone
    @ShivamVermaokdone 4 месяца назад

    Top channel for genuine content on android after the Google android developer channel.

  • @abada-s
    @abada-s 2 года назад

    Is it good to use derucedStateOf instead of rememberStateOf in all cases?

  • @youngtigersivateja
    @youngtigersivateja 2 года назад

    In your MVVM News App, how to refresh the news list using swiprefershlayout listener or when call news list api from onresume override method?
    I am new to MVVM architecture, please help me as i am calling the news list api in onresume but not in oncreate as i need to refresh the news list every time i came back to breakingnews fragment.

  • @mehmetpeker9047
    @mehmetpeker9047 2 года назад

    Can you make video about usage of native ad as a up to date and how to use in jetpack compose?

  • @duc-fw
    @duc-fw Год назад

    is it acceptable to have the key be modified within the LaunchedEffect block?

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

    I’m trying to run a recursive task every 15seconds (like call an api) on my jetpack screen, how can I achieve this with launched effect or any other Android class without using workmanager.

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

    Adam geldi ADAM

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

    This stuff would be much easier with practical uses but great content as always.

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

    In my opinion, 19:00 is missing the point.
    produceState() uses LaunchEffect in the background so that's another difference. And basically the example with the flow constructor seems to be breaking the core principles of compose, it seems like it's doing backwards writes, you are going to end up with infinite recompositions.
    Saying this as someone who is trying to wrap my head around Compose. :D

  • @user-dn1ep2kb4o
    @user-dn1ep2kb4o 2 года назад

    Hey, just finished course about multimoduling. Have a question - when services are needed? For example, if there are any pros for moving api calls to service, if these are periodic calls made with workmanager? Thanks)

    • @PhilippLackner
      @PhilippLackner  2 года назад

      Workmanager is needed when you have work that needs to be done reliably, even when your app is closed or the device restarted. Not for user initiated network calls

  • @subindsuresh4897
    @subindsuresh4897 2 года назад

    Gym Shark should start sponsoring Philipp !!

  • @leonardovalle2763
    @leonardovalle2763 2 года назад

    Hi Philipp, awesome video, thanks for the great content!
    Just a question, how would you implement a snackbar call after navigation? when i perform an action, the app navigates up and need to show a snackbar, but i am just not being able to do it...
    how would you do it?

    • @PhilippLackner
      @PhilippLackner  2 года назад +1

      Have it in a launched effect block in the screen you're navigating to if it should always show up or based on some kind of nav parameter

    • @12Playmobil
      @12Playmobil 2 года назад

      What you can also do is have a scope = rememberCoroutineScope and a scaffoldState = rememebreScaffoldState in your App() composable and a Scaffold. Your composables should expect a
      showSnackbar: (String, SnackbarDuration) -> Unit
      parameter, that you can call (for example when navigating up) like
      showSnackbar ("Your snack message", SnackbarDuration.Short).
      Your navigation composable should expect the same function parameter so you can just pass it on to your actual screen composables when creating the instances. In the end your Scaffold in App can look like this:
      Scaffold(
      ..
      state= scaffoldState
      ..
      ) {
      ..
      YourNavigationComp(
      navHost =...
      showSnackbar = { message, duration ->
      scope.launch {
      scaffoldState.showSnackbar(message, duration)
      }
      })
      }
      With this solution you have a snackbarScope scoped to the App() so your snackbar is still visible during navigation and in the new screen. (Obviously if you need a snackbar scoped to your screen you can implement the scope and Scaffold there). Hope I could explain it well and could help.

    • @12Playmobil
      @12Playmobil 2 года назад

      Your question inspired me to write an article about about the topic in Medium, because I had this same struggle some time ago. I can not post the link here but added it to my youtube bio.

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

    Привет из России. Спасибо за понятные и хорошие уроки это лучшие курсы для начинающих💗💗💗

  • @keepgoingman5829
    @keepgoingman5829 2 года назад

    Do you live in my head? How do you always know all subscriber's needs? Thank you!

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

    Hello. I saw that people place derivedStateOf inside remember. Is that wrong?Because it cash and not calculate each run

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

    Hi, Philipp, great video!
    What is yout Android Studio theme?
    Thanks =)

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

    Thanks for your educational and helpful videos! The Android Studio theme that you’re using looks awsome, what is the name of that? ⭐️🧐 Cheers from Sweden 🍻

  • @yonghunchoi8944
    @yonghunchoi8944 2 года назад

    형 너무 사랑해❤️❤️

  • @user-sb5ud7ek9c
    @user-sb5ud7ek9c Год назад

    what's the hotkey that you use at 15:28 to move the line up, through a brace, into onDispose scope?

  • @akshaytyagi9791
    @akshaytyagi9791 2 года назад

    at 3:00 you said its a terrible practise to directly call api inside composable. Can you please tell what is the best practise ?

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

      Call it from a viewmodel / use case / repository

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

    Not clear without examples

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

    Cool

  • @azatnabiullin2263
    @azatnabiullin2263 8 месяцев назад

    On 7:02 you said that code in LaunchedEffect only once when screen composed for the first time. How another Event can happen in this case? E.g. it collects first event - ShowSnackbar and then Navigate event happens but you told that code executed only once

    • @PhilippLackner
      @PhilippLackner  8 месяцев назад +1

      The launch effect block is executed once, so it subscribes to the flow once. But once a subscription is established the collect block will trigger with each event

    • @azatnabiullin2263
      @azatnabiullin2263 8 месяцев назад

      @@PhilippLackner thank you

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

      @PhilippLackner In the LaunchedEffectAnimation example. How can `counter` change? It’s just an Int parameter and is never assigned to. Would the example work the same if the first argument to LaunchedEffect were `true`? Great videos, by the way; I’m working my way through the original Compose series and have learned a lot.

  • @ravi_sorathiya
    @ravi_sorathiya 2 года назад

    What's the name of your android studio theme?
    Philip

  • @micahspecial5927
    @micahspecial5927 10 месяцев назад +1

    Im stuck with EffectHandlersTheme not detect

    • @xCrawfly
      @xCrawfly 3 месяца назад

      So was I, but you can usually get the answers in the comments.
      This is a response from @tetsuoshiva:
      When you create a new Compose project, it creates a theme named "[ProjectName]Theme". Chances are the project was named "EffectHandlers", and "EffectHandlersTheme" is the theme that was created at project creation.
      Just write your project name instead of "EffectHandlers", followed by "Theme".

  • @blockchaindevelopment120
    @blockchaindevelopment120 2 года назад

    Sir Complete jetpack compose course.

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

    I find scopes a really hard concept to get.

  • @gofudgeyourselves9024
    @gofudgeyourselves9024 2 года назад

    Thank you re baba Thank you

  • @vladalexeev8529
    @vladalexeev8529 5 месяцев назад

    I'm so stupid, I still can't grasp what is it

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

    Sadly, all `SideEffect` examples strive to be so oversimplified, that neither of them actually demonstrates the real use case of it. Like: what would happen if you do this call without wrapping in `SideEffect`? This effect handler deserves better example.

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

    This side effect makes me think twice whet i should use this or maui csharpmarkup.
    Compose makes it so much complicated especially in example.
    Why not make normal oop. İnstead of frp
    in order to conpansate for downside of functional programming,
    they added remember state etc.
    How to cover a hole
    with another thing that also has a hole. Total bullshit..

  • @pavlopavlov5169
    @pavlopavlov5169 10 месяцев назад

    Very cool lessons, please add Ukrainian subtitles.

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

    Wait, you never explained what EffectHandlersTheme is.

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

      When you create a new Compose project, it creates a theme named "[ProjectName]Theme". Chances are the project was named "EffectHandlers", and "EffectHandlersTheme" is the theme that was created at project creation.

    • @AnhBaGopDon
      @AnhBaGopDon 4 месяца назад

      @@ArthurRousseau2 It has me stumped for an hour searching google, thank alot man.

    • @xCrawfly
      @xCrawfly 3 месяца назад

      @@ArthurRousseau2 Thanks! I started to come to the comments before googling stuff and I'm so happy for that.

  • @likatest7718
    @likatest7718 8 месяцев назад

    Just example, therw is no practice :(

  • @gilbartodepiento7584
    @gilbartodepiento7584 8 месяцев назад

    Until video 9 in this playlist, I was more or less understanding the concept. After watching this one, I feel like I have totally lost the plot

  • @martinstreif2879
    @martinstreif2879 2 года назад

    At 23:44 I noticed you're german

  • @rabaka7899
    @rabaka7899 2 года назад

  • @Alexandr234
    @Alexandr234 9 месяцев назад

    nice rewriting google guides